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JOLT® is the new, fully-tested microcomputer with the exclusive on-board DEMON® debug 
monitor. You can build it, plug it in and talk to it in three hours or less . . . fora price of just $249! 


The basic JOLT® card includes an 8-bit 
MOS Technology Model 6502 CPU, which 
requires no clock, can directly address 
65k of memory, has two index registers, 
58 instructions with 11 addressing 
modes, two interrupts and includes both 
single step and address halt capahility. 
And that's only a part of it. 

JOLT's? CPU card is available 
IMMEDIATELY* in either kit form or as- 
sembled ($249 for the kit in single quantity 
and $348 assembled). Either way, the 
JOLT® CPU is completely tested prior to 
delivery. It comes complete with a termi- 
nal interface (TTY or EIA) and a unique 
software DEbugger/MONitor called 
DEMON®, for which full documentation is 
provided. It is very easy to program, and 
any JOLT® delivery includes an easy-to- 
follow assembly instruction manual, show- 
ing you exactly how to put everything 
together .. . correctly. Complete assem- 
bly should take you no more than three 
hours if you choose the CPU in kit form. 
Besides the JOLT® CPU — the 6502 from 
MOS Technology — the basic JOLT® 
card has a fully static memory accom- 
modating 512 bytes of the user RAM. The 
JOLT® CPU memory also has 64 bytes of 
interrupt vector RAM. ROM Program 
memory on the basic card consists of 1k 
bytes of monitor/debugger with an au- 
tomatic Power-On bootstrap program 
— so you can start talking to JOLT® and it 
to you as soon as you plug it in to your 
terminal. On-board Input/Output devices 
on the JOLT® CPU card include TTY 20 
milliamp current loop and an EIA inter- 
face, both full duplex. The card has high 
speed reader interface lines and 16 fully 
programmable user I/O lines with full TTL 
drive. 


Nobody, but nobody, except MAI can 
offer you an on-board debugger/monitor 
like DEMON®. It’s fully documented, 
too. 

The exclusive DEMON® Debug Monitor 
really makes JOLT® one of the most out- 
standing computer systems offered at any 
time, at any price. Even without DEMON® 
and its superior software features, JOLT® 
is the lowest cost computer system in exis- 
tence. And DEMON® is a bonus you'll 
have to use to believe. First, it self-adapts 


All kits are delivered with a complete instruction manual and packaged for easy visual identifica- 


tion of parts to aid you in assembly. 


to any terminal speed from 10-30 CPS. 
With it, you can display and alter your CPU 
register and memory locations, plus you 
can read, write and punch Hex formatted 
data... with Write/Punch ВМРЕ format 
data for PROM programmers. It has unli- 
mited breakpoint capability along with 
separate non-maskable interrupt entry 
and identification. External device inter- 
rupts can be directed to any location you 
choose, or they can be defaulted to 
DEMON® recognition. DEMON® also 
gives you (1) a completely protected ROM 
resident debug/monitor; (2) the capability 
to begin execution at any location in mem- 
ory; (3) the capability to bypass DEMON® 
entirely to permit full control by you over 
your system; (4) a high-speed 8-bit parallel 
input option; and (5) it includes user calla- 
ble DEMON? 1/O subroutines. MOST IM- 
PORTANT, DEMON® IS INCLUDED AS 
STANDARD WITH ANY JOLT*? CPU KIT 
OR ASSEMBLED BOARD! 


Obviously, the JOLT® basic card is a 
computer in and of itself. But you can add 
significantly to its capacity and versatil- 
ity by adding 4k RAM JOLT memories 
— in one card or a whole bunch. A RAM 


card kit is only $265 ($320 assembled). 


NoW. 4096 Bit RAM 4K BYTE 

The JOLT® memory card is a fully static 
4,096-bit Random Access Memory (RAM) 
with 1 microsecond access time and on- 
board decoding. It is also available now.* 


And the quantity of one price is what you 
might expect to pay in quantities of 
100... very inexpensive! 

There's also a JOLT® 1/0 card for you, 
our Peripheral Interface Adapter. You 
can’t beat the price — single kit 96 
bucks — or the function. 


Pictured above is the assembled JOLT® CPU 

card with DEMON®. just plug it in and you're 

ready to go. 
The JOLT® PIA (Peripheral Interface 
Adapter) /О card includes two PIA LSI 
chips, 32 input/output lines, two interrupt 
lines, on-board decoding and standard 
TTL drive. It is also fully programmabie 
and available IMMEDIATELY" in either kit 
or assembled form . . . at a very attractive 
single unit price ($140 assembled). 


Considering the function and capacity of 
the JOLT9 Power Supply Card, you 
probably think the quantity of one price 
— $145 — is a misprint. It isn't. 

The JOLT® family also includes a power 
supply card, which operates at any of 


three voltages — +5, +12 and —10. The 
power supply supports the basic JOLT® 
CPU card, plus 4,096 bytes of RAM and 
1/0. The only two words for the price are 
“dirt cheap." It is available for delivery 
immediately with a single unit kit price of 
$145 ($190 assembled). 


AJ ui ТҮТТҮ 


The assembled power supply card shown 
above powers the JOLT® CPU, I/O, and RAM 
Memory cards. 


You can also choose a blank JOLT™ uni- 
versal card. Or several. 


The JOLT® Universal card is completely 
nude. Its a blank you can use any way 
you wish, for control panels, T.V. inter- 
faces, keyboards, LED's, or any other in- 
terface logic, because the card's holes 
are drilled to accept 14, 16, 24, or 40 pin 
sockets and has the same form factor as 
the other JOLT cards. The single unit 
price is just $25. 

If you think you need extra cables, wires 
and the like, choose a Super Value 
JOLT™ Accessory Bag. А $55 Value for 
just $40. 

The JOLT9? Accessory Bag includes 25 
separate parts, enough hardware to con- 
nect one JOLT® card to another. Order an 
Accessory Bag for each additional JOLT® 
card. The Bag contains such necessary 
items as flat cable, connectors, cord 
spacers, hardware, wire, etc. 


THE JOLT PLAIN ENGLISH WARRANTY 


All components in the JOLT® family are 
new and fully tested prior to shipment. Kit 
components are fully warranted during the 
first 60 days of ownership. Assembled 
parts are fully warranted during the first 6 
months of ownership. If your properly as- 
sembled kit does not work, just ship your 
order back to Microcomputer Associates 
Inc. and we'll repair, replace, or refund 
your money. 


20% BONUS 


NOW! Special ONE TIME BONUS DISCOUNT. 
Order one CPU before November 10, 1975 and 
deduct 20% off of all additional cards and ac- 
cessories. (Note: Discount does not apply to 
CPU cards, assembled or unassembled.) 


We told you JOLT™ was the world's lowest priced computer system. These prices prove it. 


JOLT KITS 


(ALL PAYMENTS MUST BE IN U.S. DOLLARS) 


JOLT® ASSEMBLED PRICES 


(ALL PAYMENTS MUST BE IN U.S. DOLLARS) 


QUANTITY PRICING QUANTITY PRICING 
14 5-19 20-49 50-89 100 up 1 5-19 20-49 50-99 100и 
JOLT® CPU $249 $235 $230 $225 $215 JOLT® CPU $348 $325 $320 $315 $305 
JOLT® RAM 265 255 250 245 235 JOLT® RAM 320 305 300 295 2B0 
JOLT® 1/0 96 90 88 82 75 JOLT® 1/0 140 125 120 115 105 
JOLT® POWER JOLT® POWER 
SUPPLY 145 135 130 128 115 SUPPLY 190 175 170 165 150 
T® UNIVERSAL 
errs E A" 48 — 16 14 THE NEW JOLT FROM MAI IS AVAILABLE ONLY ON А DIRECT BASIS. 
JOLT® ACCES SORY USE THIS COUPON TODAY TO ORDER FROM ДР 
BAG 40 36 34 32 30 


ALL JOLT® KITS ARE DELIVERED COMPLETE WITH A DETAILED 
AND ILLUSTRATED ASSEMBLY MANUAL 


U 


* Order will be shipped within 15 days. 


——— "—————————" 


This coupon will bring you a JOLT™! Complete and return it. 


Microcomputer Associates inc. 
111 Main 
Los Altos, Calif. 94022 
Phone (415) 941-1977 


t., Department G 


91975 Pehaco Corporation 


Here is my check, money order or credit card payment for the 
following JOLT*? products. If a U.S. or Canadian order, please add 
$4.86 for shipping, handling and insurance. (Orders to all other 
countries are priced F.0.B. Los Altos and will be shipped FREIGHT 
COLLECT.) 


| Send me immediately: 

QUANTITY PRODUCT PRICE 
JOLT® CPU KIT $ 
JOLT®RAM MEMORY KIT 

— — — — JOLT® ПО KIT 

LL —— JOLT® POWER SUPPLY KIT 

— —— — JOLT® UNIVERSAL CARD 

—  —.JOLT9 ACCESSORY BAG 

———— — JOLT® CPU ASSEMBLED 

—L — JOLT® RAM MEMORY ASSEMBLED 

LL JOLT® 1/0 ASSEMBLED 

JOLT® POWER SUPPLY ASSEMBLED 

| TOTAL $ 


4.86 


Ф 


+U.S./CANADA SHIPPING/HANDLING/INSURANCE 


NOTE: CALIFORNIA RESIDENTS, +6% SALES TAX 
TOTAL REMITTANCE (U.S. DOLLARS ONLY) $ 


MAIL Pehaco Corporation, JOLT® Sales Agents 
YOUR Microcomputer Associates Inc. Dept. G 
ORDER 111 Main St., Los Altos, Ca 94022 

TO: 


All orders subject to the prior approval of the manufacturer. 


NOW! Special ONE TIME BONUS DISCOUNT. 

Order one CPU before November 10, 1975 and 20% 
deduct 20% off of all additional cards and ac- BONUS 
cessories. (Note: Discount does not apply to 
CPU cards, assembled or unassembled.) 


PLEASE CHARGE THE TOTAL TO MY CREDIT CARD: 
BANKAMERICARD # 


MASTER CHARGE # 


20% 
BONUS 


(include 4-digit #) 


My credit card expires on 


SIGNATURE 
All credit card orders must be signed!) 


1 UNDERSTAND THAT ALL U.S. ORDERS WILL BE SHIPPED VIA U.P.S. AND ALL 
INTERNATIONAL ORDERS WILL BE SHIPPED BY AIR. SEND MY ORDER TO: 


NAME 
ADDRESS 


ORGANIZATION 


CITY | 


STATE ZIP 
PHONE 
(Include Area Code) 
*Make your check payable to: Microcomputer Associates Inc. 
International Orders: Payment should be cabled to Account 
#00417-06355 Bank of America, 215 So. Murphy 
Avenue, Sunnyvale, California, USA, 94086 


——————— —— Y 


for fast, 


to all leads on dual-in-line 
IC packages 


No more shorting across 
DIP leads... just quickly 
clip on an IC TEST CLIP 
to bring DIP leads out for 
safe attachment of scope 
probes and other leads. 
Ideal for signal input, trac- 
ing, troubleshooting, etc. 
Patented precision, ‘’con- 
tact comb” design guar- 
antees no shorting be- 
tween DIP leads. Probes 
can hang ‘‘no-hands"' free 
on Test Clip terminals in 
card racks (unique — see 
photo). Engineered Me- 
chanical clamping plus 
gold-plated phosphor 
bronze terminals provide 
superior electrical con- 
tact. A/so unequaled as a 
DIP removal tool. 


TC-16 fits 
16-pin DIP's, etc 


We honor M.C. and B.A.C. charges. 
Add sales tax on OH and CA orders. 


SHIPPING/HANDLING|C.O.D. 


fees from Up to $10.00 $1.00 |$ .70 


(F.O.B. Painesville on company P.O.'s.) н 510.01 10 $25.00 1.50 
pil ros this chart. 
Dealer inquiries invited 


All products guaranteed to meet or exceed published specifications 
} AP PRODUCTS INCORPORATED 


25.01 1050.00 200! 90 


Вох 110-G € Painesville, OH 44077 ө 216/354-2101 


Super-Versatile™ 
building blocks for experimental circuits 


Universal .10'" matrices of Create custom breadboards in minutes 
solderless, plug-in tie points with these new instant-mount strips. 
For ail DIP's and disci DISTRIBUTION STRIP (top) contains 
ona sand discretes 2 continuous buses of 12 connected 4- 
with leads to .032" dia. — tie-point terminals. Size: 6.5" by .35"". 
Interconnect with any solid TERMINAL STRIP contains 128 5-tie- 
wire up to No. 20 A.W.G. point terminals, holds up to nine 14-pin 
————— DIP's. Size: 6.5” by 1.36". Integral, 
non-shorting, instant-mounting back- 
ing permits quick build-up of special 
ORDER BY PART NUMBER breadboards using any mix of strips. 
923277 distribution strip . . . $2.50 
923261 terminal strip . . . .$12.50 


Nickel-silver terminals 


Other models available. 


We honor M.C. and B.A.C. charges. d=  SHIPPING/HANDLING|C.O.D. 
Add sales tax on OH and CA orders. +5 from — Upto $10.00 $1.00 | $ .70 
(F.O.B. Painesville on company P.O.'s.) this chart $10.01 to $25.00 150 80 
Dealer inquiries invited * 2501105000 200 


All products guaranteed to meet or exceed published specifications 
Bu AP PRODUCTS INCORPORATED 


Вох 110-G @ Painesville, OH 44077 @ 216/354-2101 


a’ 


solderless 
plug-in 


fastest, most reliable 
method known...to build, test 
and modify experimental circuits 
8-bus distribution system 
plus universal .1” by .1" matrix 


of solderless, plug-in tie points 
all in one integral device. 


High-performance A P Super- 
Strip component matrices consist 
of 128 terminals of 5 tie points 
each. The 8 buses of 5 connect- 
ed 5-tie-point terminals не for 
: are voltage, ground, reset and cloc! 
with leads up to .032 dia. lines, shift command, etc. New, 
Interconnect with any solid wire non-shorting, insfant-mount 

up to No. 20 A.W.G. backing and quick-removal 

ug — ame screws are supplied... use several 

ORDER BY PART NUMBER Super-Strips to create large-scale 

. 923252 (nickel-siver terminals) breadboards on panels up to 
923748 igoli-plated terminals) 1/8" thick. 


Accepts all DIP's and discretes 


We honor M.C. and B.A.C. charges. 
Add sales tax on OH and CA orders. 
(F.O.B. Painesville on company P.O.'s.) 
Dealer inquiries invited 


All products guaranteed to meet or exceed published specifications 
| AP PRODUCTS INCORPORATED 


Вох 110-G © Painesville, OH 44077 € 216/354-2101 


d љ. SHIPPING/HANDLING|C.O.D. 
bes from Up to. $10.00 $1.00 |$ 70 

3 $10.01 to $25.00 1.50 | | 
this chart. 26.01 to 50.00 2.00 90 


for fast 
building and 
testing of 
circuits 


photo 
ACE 227 


Р On all models... 

f simply plug in your 

obsoletes А ipn and inter- 
A connect with 22-ga. solid 
ordinary wa 7. wire. All models satan: all 
breadboards "us" ^ DIP's, TO-5's and discretes 
with leads up to .032'' diameter. 

Multiple buses can easily be linked for power and ground distribution, 
reset and clock lines, shift command, etc. Bases: gold-anodized alumi- 
num. Terminals: non-corrosive nickel-silver. Four rubber feet included. 


Board Size 
(inches) 


4-9/16 x 5-9/16 
4-9/16 x7 
4-9/16х 7 
6-1/2 x 7-1/8 
8x9-1/4 
10-1/4x9-1/4 


We honor М.С. and B.A.C. charges. Add 
Add sales tax on OH and CA rp fees from Up 01000 m 
(F.O.B. Painesville on company P.O.'s.) ` $10.01 to $25. 
Dealer inquiries invited this chart. 25.0) 1050.00 — 200 


All products guaranteed to meet or exceed published specifications 
BB A P PRODUCTS INCORPORATED 


Вох 110-G e Painesville, OH 44077 € 216/354-2101 
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In the Christmas BYTE you'll find the following morsels: 


To quote an ancient philospher, "nature abhors a 
vacuum." Chris Ryland's Opinion: The Software Vacuum 
describes a void in the personal use computer marketplace. 
Will nature in the form of profit motive come in and fill the 
software vacuum? Only time will tell... 


Strange things sometimes occur in the electronic pathways 
of a computer. Putting on your detective hat may occasionally 
be required — in which case Alex. F. Burr's review Logic 
Probes — Hardware Bug Chasers will give you valuable 
information on several commercial products which can help 
debug your designs. 


On the same theme but in the foreground this time, Robert 
Baker and John Errico have provided an article on a fairly 
sophisticated Powerless IC Test Clip which you can construct 
for $20 or so in parts. For the do-it-yourselfer, this design 
results in 16 little binary voltmeters which can be clamped 
onto an integrated circuit to examine the logic levels at each 
pin. 


What is a Character? You can find out by reading Manfred 
Peshka's tutorial on some of the basic concepts of program- 
ming and information systems work. Old hands at the 
programming arts will find this to be an interesting review, and 
readers new to programming will find it necessary background 
material. 


After an interruption, the LIFE Line series continues this 
month with the third installment. In LIFE Line 3 you'll find 
the beginning of information on the interactive commands 
which are decoded by the program. 


The Flip Flop is an important element in designs used with 
computer chips and peripherals. William E. Browning has 
provided this article to introduce the less experienced readers 
to this fundamental building block. 
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In This BUTE 


Read Only Memory Technology can be used in situations 
ranging from clever logic and interface design to storage of 
systems programs in a computer. In his article on the subject 
in this issue, Don Lancaster gives some background informa- 
tion about ROM applications and several suggestions con- 
cerning their use as design elements. 


What is The World’s Smallest Computer System? Well, at 
this time it looks like the HP-65 pocket-size programmable 
calculator might qualify for the title. Find out why by turning 
to Richard Nelson’s article on the subject. 


The last BYTE featured a comparison of the Motorola 6800 
CPU chip with a new contender from MOS Technology. In this 
issue, Gary Kay of Southwest Technical Products Corporation 
presents some information on the Motorola 6800 package his 
firm is supplying. What SWTPC has done is to take the 
standard parts, combine them with an attractive case, power 
supply and PC boards — and put the result into a package as a 
kit for readers to build. 


What is it like to build an Altair computer kit? In his First 
Person Report: Assembling an Altair, John Zarrella describes 
his experience with the MITS product, from his decision to 
purchase, through assembly and hardware debugging. 


Computers are fundamentally synchronous machines — 
they beat to the tune of a periodic clock. With program timing 
loops, a computer can be made to count the beats of its clock. 
You can find out how to do this by reading Jim Hogenson's 
article Can Your Computer Tell Time? 


When assembling complicated logic systems, one of the best 
methods for new and experimental work is use of solderless 
wire wrap interconnection. Some pointers on prototype 
assembly are found in Photographic Notes on Prototype 
Construction. 


And on the cover, artist Robert Tinney illustrates the 
impact of these new toys upon traditional relationships. 


What This Country Needs 
ls a Good 8-Bit 
High Level Language 


Have you ever tried to talk 
to a person who speaks a 
language other than your 
own? You know that the 


person must think as a 
rational, sentient being or 
you wouldn't make the 


attempt to communicate. As 
a human being your 
conversational partner's basic 
thought patterns are of 
necessity similar. Yet you 
can't understand him and he 
can't understand you. There 
are ways around this 
problem, given а sincere 
interest in communications 
by both parties. 

An analogous problem 
exists in the field of personal 
computing as it is practiced 
by the readers of BYTE. If 
you translate the words 
referencing human beings 
into words referencing 
computers and reread the 
preceding paragraph, the 
result will be a corresponding 
statement about the 
computer communication 
problem: In the home brew 
computer world, there are a 
number of different 
computer architectures, all 
speaking different machine 
languages. There are even 
dialects of machine languages 
since each home brew 
designer or manufacturer 


Editorial 


by 


Carl Helmers 


makes specific choices about 
address space allocations and 
input/output port 
assignments used with the 
standard computer chip 
designs. Yet all of these 
machines аге potentially 
programmable to do similar 
functions. 

Like two human beings 
facing each other but 
speaking different languages, 
computers can talk to each 
other on compatible channels. 
But making sense — that is to 
say, executing the same 
programs — is another matter. 
It is possible to connect an 
Altair up to a Scelbi 8H 
product using an RS-232 
interface. The link can be 
made and every bit of every 
byte sent (for example) from 
the Altair will be received and 
digested by the Scelbi. But 
unless the machines have 
common referents and means 
of translation, the 
information sent will be no 
better than "noise" — just as 
a foreign language perceived 
by a person conveys no more 
meaning than an arbitrary 
sound until the language is 
learned. Having a working 
communications channel does 
not guarantee that the 
communications sent will 
mean anything. 


Levels of Intelligence 


Given two or more 
different computers and 
compatible electrical 


interfaces between them, the 
simplest and easiest form of 
common understanding is at 
the level of raw data to be 
processed by the different 
computers. A binary number 
is a binary number 
independent of the machine 
for which it was generated. 
The fact that the bit string 
11000111 means "load 
accumulator from memory" 
in the machine language of an 
8008 and means “You fool — 
that's an unimplemented op 
code" for the Motorola 6800 
is an accident of hardware 
design at two different 
companies. In either case, as 
data, the binary number 
11000111 means an integer 
value of 199. Similarly, an 
ASCII character is an ASCII 
character independent of the 
place and time of its creation. 
Given the decision to use 
ASCII for communications — 
or binary numbers, for that 
matter — both parties to the 
communication can talk 
characters or numbers. These 
simple data formats provide 
an easily implemented link 
between computers which 
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SILL GODPOW ELECTRONIC d 


W ЕЕ N 
‘SH You я ayang HOLIDAY SEAS 


AND HOPE THAT 76 WILL BE YOUR 
<) BEST YEAR EVER С 


JR YOU are into toysul tinkering as well 
AS NAVY computer ecunff e YOU might like 


BIGGER DIGITS... 
i WE HAVE A SUCCESSOR its neck (t ee е 
give your eyes а 
ues Tn Vm Pm Ov “Electronic Projects 
3/10" displays "CHEAP CLOCK KIT"! 


BRIGHTER DIGITS... 
segment and driver 
transistors included 


for Musicians” 


BY CRAIG ANDERTON $6.95 shpg 


AN IDEAL BOOK FOR PEOPLE INTO 

MUSICAL ELECTRONICS...contains 4 chapters for be- 
ginners on practical electronics, so that even 
complete novices can create working devices. The 
book then describes 19 projects suitable for any 
level of experience, such as a ring modulator, 
preamp, mixer, battery eliminator, miniamp, bass 
fuzz, compressor, & 12 more. Also has sections on 
troubleshooting, finding more informa- 

tion, a forward by guitarist Joe 


LJ 
S; Walsh, and a recording that 
€ demonstrates the sound of 
S the projects. 


MORE RELIABLE DIGITS... 
sockets included for 
IC and for readouts 


THE RIGHT NUMBER OF DIGITS... 
6 digits for hours, minutes, 
and seconds. Use as 12 or 24 
hour clock, 50/60 Hz 


AND NOT JUST THE DIGITS... 
We include all parts you need < А 
to make a working clock, in- fl^ Á ‘ 
cluding the PC board, trans- Daiwa 


former, al! components. You 
supply the case and hardware 


for any other electronics enthusiast you 
know. „Зсоре our FLYER for more toys! 


ROM SOARD ‘SPECIAL OFFER 
AK X © PRE-PROGRAMMED FOR 8080 S225 


By special arrangement with a software house (meaning we pay them royalties), we've got 4K by 8 EROM boards 
pre-programmed with 8080 assembler, editor, and executive routines. It's still the same price as one of 
our stock 4K X 8 EROM board kits; we save enough on the programming (by doing lots of EROMs at a time) to 
absorb the software royalty so that you don't have to. And since these boards are EROM rather than mask, 
you can easily make changes in the program if desired. Speaking of changes: although these routines work 
out really well, we recognize the possibility that some bugs could pop up, or we may discover improvements 
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charge. We use our 8K x 8 EROM board as the basis---so it's expandable! 
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does not require a_ large 
amount of software 
intelligence on the part of 
receiving and sending 
computers. 11 does not matter 
whether such a link is in the 
form of tape cassettes sent in 
the mail or a direct RS-232 
connection when all the 
neighborhood hackers get 
together for a multiprocessor 
powwow and computerized 
crap game. ASCII and binary 
numbers can be shuffled back 
and forth with the assurance 
that, at this data level of 
coding, the information will 
be understood by both 
parties. 

The communication 
represented by binary 
numbers or ASCII encoded 
data is not at all what might 
be called true understanding 
between the two computers 
involved. Sending data is a 
first step, but it is by no 
means the ultimate. The 
significance of the 
communication at this level 
must be determined by the 
human beings who 
manipulate the data being 
sent. There is no direct way 


of affecting the 
understanding — the 
programming — of the 


computer which is dutifully 
receiving the ASCII or binary 
data in this simple fashion. 

Simple transmission of 
data across a parallel-serial- 
parallel or  parallel-parallel 
interface enables the users of 
the computers to talk to one 
another, but the computers 
which carry out the exchange 
"couldn't care less.” The 
computer in this type of an 
exchange is simply serving as 
a ''dumb'' transmission 
channel. 


BASIC is an adequate 
language — but it has its 
drawbacks. 


Borrowing again from the 
analogy to human beings, this 
data level communication 
between computers might be 
compared to the non-verbal 
emotional forms of 
interpersonal exchange. 
Common languages and 
verbal understanding are not 
required for humans to 
exchange emotional states, 
using music, facial gestures 


and other body motions 
which are inherent in the 
nature of the beast. But to 
exchange knowledge and 


practical data humans must 
speak a common language; it 
is not an accident that verbal 
activity and the tools of 
language are so much a part 
of the dominant species on 
this planet. If merely sending 
data represents a low level of 
communications intelligence 
between computers, what 
does it mean to transmit a 
higher level of intelligence? 


Program Level Intelligence 


To transmit data between 
computers is the first step 
toward a higher level of 
communications among 
diverse types of computers. 
Every computer on the 
market can handle 7-bit 
ASCII and other forms of 
information encoded into 
8-bit bytes. (Of course, it 
may be easier to program 
ASCII data manipulations on 


YOU FOOL — THAT'S 
AN UNIMPLEMENTED 
OP CODE! 
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some machines than оп 
others.) Having a computer 
which can easily be 


programmed (possibly with 
no human intervention) as a 
result of an ASCII exchange 
with a computer of a 
different internal architecture 
is the essence of this next 
level of intelligence in 
intercomputer communica- 
tions. In such program level 
exchanges the computers are 
speaking to each other in the 
form of abstract program 
representations which can be 
automatically translated into 
specific machine language 
representations for execution. 

In the previous analogy, 
this is like human beings 
exchanging information and 
thought in a commonly 
understood language — for 
example, English. Each 
person who understands the 
language has incorporated 
within his mind a 
"translator" which creates an 
internal understanding based 
upon what was heard. The 
result of this translation — 
which must be consciously 
performed — is an 
understanding of the message 
which can be used as a basis 
for further thoughts. 
Emotional data is a much 
more directly perceived input 
(although it may of course be 
colored by thoughts). But 
verbal inputs require 


cogitation and analysis before 


they can be used and 
integrated. 
The Goal: Exchange of 
Programs 


The goal of program level 
interchange between 
computers is thus the ability 
to communicate 
understandable and 
potentially executable 
programs between computers 
of different design. When this 
goal is achieved it will be 
possible for a reader in one 
corner of the technological 
world — for instance an 8080 
user — to develop a neat little 
utility program which can be 
sent to a friend in another 
corner of the technological 
world who has just completed 
a different processor such as a 


PACE machine. Since the 
program is recorded and 
communicated using the 


program level techniques, the 
recipient need only read the 
ASCII representation from 
the communications channel 
and process this data with a 
suitable “translator” in order 
to obtain a new executable 


program for a different 
machine design. 
This program level of 


exchange is a well known 
technique which has been 


developed very thoroughly 
over the past 15 years after 
computer science left its 


formative years of the 1950's. 
It is the technique of high 
level languages and compilers. 
The /anguage is the machine 
independent notation for the 
programs which are to be 
exchanged. The compiler is 
the computer program which 
carries out the translation. 
(Variations on this technique 
of course exist; for instance 
some languages like BASIC 
and FOCAL rarely have 
compilers, but typically use 
‘interpreters’ instead to 
compile, then execute 
statements one by one.) In 
the computer world at large, 
of course, there is no 
unanimity about choices of 
languages — and there no 


doubt will be considerable 
variation in program 
representation philosophies in 
this personal microcomputer 
field. Be that as it may, 
exchanges at the program 
level are needed and 
computer languages/com- 
pilers are the technique for 
accomplishing such exchanges 
with minimum machine 
dependence. 

So that's the story behind 
the need for a good 8-bit high 
order language. The home 
brew computing field is much 
more extensive than the 
confines of just one computer 
architecture, and the 
technological problem of 
passing 8-bit bytes all over 
the place is not at all 
impossible. The need is there, 
but can it be satisfied? 


What Exists Now? 


What currently exists in 
the way of high level 
languages for the field of 
home brew computers is 
limited. Currently available is 
only one language — BASIC 
— which to a certain extent 
satisfies the need for a good 
language. BASIC now exists 
for the MITS Altair, and will 
soon be offered by several 
other manufacturers. As such 
it is the only high level 
language which both exists 
and will (hopefully) run the 
same programs on any one of 
these small computer 
systems. As a high level 
language, BASIC is adequate 
but it has a few drawbacks: 

— Descriptive names of 
variables are impossible with 
single character identifiers. 
— Only a primitive 
GOSUB/RETURN facility 
exists for subroutine 
linkage, and parameter 
passing is not built into the 
language. 

— The language BASIC is 

interpretatively executed, 

which means that each 
statement is "compiled on 
the fiy" and executed 
whenever it is encountered. 

(Pre-scanning of programs 

and reduction of the source 


text is sometimes done, 
however.) An interpreter is 
necessarily slower than an 
equivalent compiler’s object 
code. 

— BASIC is missing the 
more advanced software 
tools such as the 
(F-THEN-ELSE construct, 
and statement grouping 
constructs, like the PL/1 
DO... END block. 

— Only line numbers may 
be used to label places in 
the program. 

Now don't make the mistake 
of concluding from this 
criticism that BASIC is 
useless. Far from it. Any high 
level language which works 
as well as BASIC is better 
than none at all in the 
majority of programming 
circumstances. This is because 
for most problems the minute 


details of execution are 
unimportant, provided that 
certain functional building 


blocks of software (provided 
by the higher order language) 
are available to usc. 

The BASIC language has 
been used as a tool for 
initially teaching computer 
programming concepts, and 
has done so from its 
inception in the early 1960's 
at Dartmouth. There are also 
innumerable tutorial books 
about BASIC, due to its 
widespread use in the 
educational field. |t is 
certainly the case that in 
most implementations BASIC 
is a quick and conversational 
way to write simple programs 
at a terminal. The criticisms 
have to do with features in 
contemporary computer 
language technology which 
are not present in BASIC, but 
which are extremely useful 
when writing programs. 


An Alternative to BASIC 
Criticism without giving an 
alternative is an empty 
activity. The purpose of 
criticism is to find a way to a 
better approach. So what 
language exists, can be 
dreamed up, or adapted to 
the small systems context — 


and provides a better 
alternative to BASIC? At 
present there is one language 
which was expressly designed 
for systems programming and 
applications programming for 
microprocessors. This 
language is called PL/M, 
which is a registered 
trademark of the Intel 
Corporation. The origins of 
PL/M can be traced back to a 
book published in 1970 by 
three compiler specialists, W. 
M. McKeeman, J. J. Horning 
and D. B. Wortman called A 
Compiler Generator 


(Prentice-Hall, Englewood 
Cliffs NJ). 

XPL is a subset of the IBM 
language PL/1. The XPL 


subset is designed to 
eliminate many extraneous 
bells and whistles from PL/1, 
retaining only those features 
most needed for writing 
compiler programs: Simple 
character string and binary 
data, manipulations of such 


In most programming 
circumstances, any high 
level language is better 
than no high level 
language at all. 


data, and a block structured 
procedure oriented language. 
Another design criterion of 
XPL is that it had to be a 
simple language so that its 
compilers could easily 
generate efficient object 
programs without burning up 
incredible amounts of 
computer time. The authors 
of the Janguage and the book 
describing it succeeded well, 
producing a powerful 
language design system which 
has been used in a number of 
large projects. 

Now, as it turns out, the 
features which are in XPL are 
in many respects the features 
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PL/M is becoming an 


industry standard 
language: The 
computer language 


equivalent of a “black 
box” integrated circuit. 
BYTE would like to see 
a PL/M compiler 
adapted to the home 


brew computer 


context. 


which are desirable for a 
programming language used 
with microcomputers for 
both applications and systems 
programming. XPL is not too 
far removed from assembly 
language and becomes very 
handy as a way to generate 
large programs without 
getting bogged down in 
details. This fact makes XPL 
a language of far more utility 
than a mere compiler writing 
tool. 

When the time came for 
Intel to commission a high 


order language for 
programming of their 
microcomputers, the XPL 


language and compiler had 


DIAGNOSTICS: Documentation 


BYTEs. 


BYTE #2, p. 54, Fig. 3. 
An inverter (e.g., 1/6 7404, 
or 1/4 7400) should be 
inserted between the CE 
inputs of the 7489 circuits 


Dan Clarke (105 Fir 
Court, Fredericton NB, 
Canada E3A 2E9) notes that 
the originate modem transmit 
frequency definitions (Fig. 14 
and text of “Serial Inter- 
face"), page 35, BYTE #1, 


Mode Data 
Originate Mark 
Originate Space 
Answer Mark 
Answer Space 
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Transmit Freq. 


been proven in several years 
of practical use by several 
compiler writing 
organizations. Its practicality 
as a systems programming 
tool no doubt resulted in the 
use of XPL as a model for the 
new PL/M language. PL/M is 
effectively an adaptation of 
XPL to the context of a 
microcomputer with — 8-bit 
data quanta and 16-bit 
addressing. The result is a 
language which looks very 
much like XPL — with a few 


keyword substitutions and 
additional features. This 
resemblance is sufficiently 


close that at least one version 
of PL/M has been 
implemented simply by 
modifying a working XPL 
compiler, although  Intel's 
original was implemented in 
FORTRAN. 


PL/M as a language 
possesses many desirable 
attributes which are not 
found in BASIC. These 
attributes include the 
PL/1-like statements апа 
statement groups, long 
descriptive names for 
variables and labels, block 
structure, and  subroutine 


linkages with parameters. As 


of bugs in previous 


and the 7400 which drives 
them in the original drawing. 
Thanks to Martin E. Haring, 
Edison NJ and several other 
readers for pointing this out. 


are incorrect. Using the 
Motorola M6800 Micro- 
processor Applications 
Manual page 3-32 as a source 
of data, the following table 
should correct the matter: 


Receive Freq. 


1270 Hz 2225 Hz 
1070 Hz 2025 Hz 
2225 Hz 1270 Hz 
2025 Hz 1070 Hz 


a systems programming 
language for microcomputers, 
the PL/M language adopts 
some of the features of an 
absolute assembler — there 
are location counters for 
program code and data which 
can be set during a 
compilation. To top itall off, 
the PL/M language is a 
relatively simple one which 
can potentially be 
self-compiled upon a small 
(but not minimal) home brew 
system. 

At the time of this writing, 
PL/M is fast on its way to 
becoming an industry 
standard. |t is definitely a 
language which has the 
potential for adaptation to 
the software requirements of 
the more advanced 
programmers in BYTE’s 
readership — yet at the same 
time it is simple enough for 
the novice to understand. At 
the present time, however, 
only cross compilers — large 
programs running on big 
machines — are available for 
PL/M. There are PL/M 
versions currently їп the 
works or producing code for 
the 8080, the 6800 and 
PACE microcomputers — but 
all are cross compilers. These 
cross compiler versions are 
widely used via time sharing 
networks by a variety of 
industrial and commercial 
users of microprocessors. This 
acceptance indicates that 
PL/M is a language which is 
likely to be around for some 
timc. 


A Call For Compilers 


So PL/M is the tool which 
the industrial and commercial 
world uses for efficient code 
generation with a high level 
language for microprocessors. 
Will this technology be made 
available in the home brew 
computer markets? Yes. One 
reason for writing this 
editorial is to point out the 
existence of PL/M and direct 
a few BYTE readers to 
appropriate sources of 
information. In future issues, 
BYTE will be getting into 


Information Sources 


PL/M: 

8008 and 8080 PL/M 
Programming Manual, 
MCS-451-0275-10K 

Intel Corporation 

3065 Bowers Ave., Santa 
Clara CA 95051 

This describes 8008/8080 
PL/M as originated by Intel. 


PL/M6800: 

PL/M6800 Programmers 
Reference and PL/M6800 
Language Specification 

Intermetrics, Inc. 

701 Concord Ave. 

Cambridge MA 02138 

These manuals describe 
the version of PL/M being 
marketed for the 6800 pro- 
cessor. 


As this issue goes to press, 
National Semiconductor has 
announced a version of PL/M 
called "PL/M-*" for the PACE 
system. Further details will 
be provided by BYTE as they 
become available. 


more of the details of PL/M 
as a language. Until then, the 


accompanying list of 
information sources will have 
to suffice. 

A second reason for this 
editorial is to serve as a call 
for compilers. What is needed 
is a compiler for PL/M or a 
similar language which will 
run on a typical 16K (RAM) 
8-bit microcomputer using as 
many as three serial 1/O 
devices for multiple passes 
through the data of a source 
program. Ultimately there 
should be one such 
self-compiler program for 
each of the major 
microcomputer chip 
architectures. The compilers 
should be written with 
system design flexibility in 
mind (in other words, 
modularity throughout and 
isolation of hardware- 
dependent portions to 
specific modules). Who will 
be the first person, club or 
firm to provide such a 
self-compiler? m 
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Opinion: 


The Software Vacuum 


by 

Chris Ryland 

25 Follen St. 
Cambridge MA 02138 


There is a software 
vacuum. That fact has 
become increasingly clear in 
the past few months. 


Take a look at the 
situation. At the time this is 
written there's only опе 


company (MITS) offering a 
proprietary software product 
(BASIC) aimed directly at the 
microcomputer hobbyists. 
It’s true that the People’s 
Computer Company (PCC), 
the MITS Altair User's 
Group, and a handful of 
other user groups offer access 
to growing libraries of 
applications programs. Some 
microsystem manufacturers 
also supply “bare bones” 
system software with their 
machines, but the user is 
lucky if these bones consist 
of as much as a rather bare 
monitor, editor and 
assembler. Such software is 
just as important to a serious 
hobbyist's system as the 
hardware. So when | say 
there is a software vacuum, | 
mean there is an absence of 
commercially developed and 
marketed larger scale 
software products. 

But why should this 
matter to me, as a hobbyist? 
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What do | mean by 
larger-scale, and why should 
the hobbyist market be 
invaded by commercial 


software vendors? In answer, 
let me give a concrete 
example. Suppose | want to 
write a "desk calculator" 
program for my system. Га 
like it to include all the 
scientific functions of a 
powerful calculator, such as 
sine, cosine, tangent, arcsine, 
the hyperbolic functions, etc. 
| would feel competent to 
design and write the user 
interface (e.g, keyboard 
input) sections of the 
calculator, but when it comes 


to even the floating-point 
arithmetic (let alone the 
scientific) functions, I’m 


totally lost. What do | do? 
Give up? Scour the different 
user groups software 
offerings, piecing together 
little routines from here and 
there? Take a course in 
applied numerical analysis 
and learn enough theory to 


do all the programming 
myself? No. Ideally, I'd 
browse through several 
software catalogs from 


commercial vendors, picking 
out the best math package for 
my needs. It would be 
relatively inexpensive, 
because of competition 
among the various vendors. 
And since the time | save by 


buying the package 
commercially is substantial, 
l'd consider it to be a 
larger-scale product 


(physically small though it 
may be). Finally, and most 
important, is the assurance of 
quality that | get — the 
programs that | buy should 
be backed up by a 
guarantee; if they don’t 
work correctly, | can have the 
problem fixed by someone 
who’s an expert at that sort 
of thing. In fact, any 
problems discovered by other 
customers of the supplier will 
be automatically corrected 
and reported to me. 

l'm not pointing out 
anything surprising, though. 
What /s surprising is that this 
lack of software is no one's 
fault. Why? The reasons will 
become clear as we examine 
the basis and effects of the 
vacuum more carefully. 

The most obvious 
explanation for the software 
vacuum is the newness of our 
field. It’s very easy to drawa 
parallel to the very early days 
of "real" computers, when 
every manufacturer was 
scrambling to produce 
hardware. The importance of 
software wasn't recognized, 
and it was simply left behind 


in the dust. Since then, 
however, software has 
become the major 


... l'd like to browse 
through several 
software catalogs 

picking out the best 
package for my needs. 


component, in cost, size, and 
complexity, of апу large 
computer system, since 
nothing can be done without 
it. 

The parallel is completed 
by noting that, now, the big 


'"scramble'" in micro- 
computers is to get out the 
hardware. People do 


sometimes learn from history, 
though. Microsystem 
suppliers have realized that 
naked machines are close to 
useless, and many are offering 
at least the bare bones system 
software mentioned earlier. 
The problem here is that 
many of us want to use our 
home or business system for 
something (e.g., as a powerful 
desk calculator) and don't 
necessarily want to do all the 
programming ourselves. 


This situation is eased, for 
example, by the availability 
of a BASIC system from one 
major supplier. Unfortunate- 
ly, for the "from scratch" 
hobbyist, the difficulty still 
remains, since software like 
BASIC is much more 
expensive as a stand-alone 
product (and is usually out of 
the price range of most of 
us). Again, since the average 
hobbyist would be lost when 
faced with the task of 
constructing his own BASIC 
system, he's thereby 
automatically cut out of the 


You'll go nuts over 
our computers! 


And the Sphere Computer System costs 
less than anyone else’s terminal. 


Completely intelligent micro-systems . . . that’s what we offer. Just look at the features, and the 
prices. No compromising, with no short cuts! Recently at WESCON, SPHERE also demonstrated its 
new, full-color and BAW graphics terminal — and we have other new products, to be just as 
revolutionary as the SPHERE 1 SYSTEM was when we released it last June. SPHERE 'R & D' will keep 
ahead of your demands, no matter the state of the art. Take one look at our catalogue, then call or 
write us today. 


SPHERE 1: This system includes the Motorola 6800 microprocessor, KIT ASM SPHERE 4: Includes all of the features of SPHERE 3, except the 

4K RAM, 1K EPROM (containing an EDITOR, ASSEMBLER, DEBUG- $6100 $7995* cassette has been replaced by an IBM-compatable Dual Floppy Disk 

GER, COMMAND LANGUAGE, CASSETTE LOADER, DUMPER, System. This system includes a Disk-operating system and BASIC 

UTILITIES), a REAL-TIME CLOCK, plus 512 character video interface, Language and a 65 LPM line printer. 

with full ASCII keyboard and numeric/cursor keypad, power supply, 

chassis, manuals, and associated parts. OTHER SPHERE PRODUCTS: Light pen option; fullcolor and B/W 
(various) video graphics system; low cost Dual Floppy Disk System; and fuli 

SPHERE 2: Includes ай features of SPHERE 1, plus serial communica- line of low cost peripherals. 

tions, and audio cassette or MODEM interface. 


SPHERE 3: Inicudes all the features of SPHERE 2, plus memory "This ASSEMBLED SPHERE System includes the complete chassis, and video monitor 


totaling 20K which is sufficient to run full extended BASIC Language. as pictured below. 
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The Whole System: 
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SPHEHE 


CORPORATION 


791 South 500 West Dept. 1211 846 
Bountiful, Utah 84010 7 (801) 292-8466 


13 


Suppose you could 
make working Xerox 
copies of CPU chips, 
how long would chip 
manufacturers be 
around? 


Hobbyists сап help 
generate commercial 
interest in producing 


software. 
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legacy of  widely-available 
BASIC programs. 
Now why can’t we throw 


‘the blame on the CPU chip 


manufacturers? Because, 
clearly, their proper market is 
the OEMs (Original 
Equipment Manufacturers), 
and thus their main concern 
regarding software is to 
provide their OEM customers 
with developmental systems 
of hard and software, leaving 
the hobbyist nearly 
completely, if not 
intentionally, out of the 
picture. 

What about the other 
potential suppliers of 
software? Look at the 
situation of a typical software 
house, or vendor. They must 
ask, "What kind of hobbyist 
market exists? How big is it, 
and how can it be reached? 
What kind of return on 
investment can be expected 
from a venture in this area?" 
These are tough questions for 
a company whose existence 
depends оп successful 
marketing of software 
products, even though the 
answers might scem obvious 
to us. But keep in mind that 
the existence of BYTE is 
among the first indicators of 
a widespread hobbyist 
interest in computing, and 
we're only a few months old. 


Furthermore, there's the 
problem of proprietary 
programs, a problem hard to 
appreciate from the 
hobbyist's point of view. It 
stems from the softness of 
software: Hardware can only 
be physically in one place at 
one time, but software, 
because its copying cost is 
(relatively) so low, can 
virtually be in many places at 
once. For example, an 
institutional computer 
installation signs a 
proprietary contract when it 
buys a program product. 
Such contracts typically 
restrict use of the software to 
one computer system ог 
customer site. This is one of 
the major reasons the 
institution is not likely to 


lend or sell such a product to 
other installations. But a 
hobbyist, even though he 
might sign a similar contract, 
is much more likely to help 
out a friend by swapping a 
program for others, or by 
lending a copy to someone 
else. And this is deadly 
poison for any sort of 
commercial market. To take a 
concrete, if absurd, 
illustration, suppose you 
could make working Xerox 
copies of CPU chips — how 
long would the chip 
manufacturers be around? 
Another simple fact of 
proprietary-program life is 
that such programs cost a lot 
to develop and market. 
Unless the market is large, 
this means high prices, which 
a big computer installation 
can usually justify, but which 
an individual just can’t 
afford. It’s true that there’s a 
difference in scale between 
large and micro system 
software, but both, in their 
own spheres, are costly to 
commercially develop and 
maintain. So, the software 
vendors may simply not have 
been able, even if willing, to 
enter the microcomputer 
software market. 
Continuing with our 
search for potential software 
suppliers, we arrive at the 
grass roots level: The home 
experimenter who's 
developed a good product 
with long hours and minimal 
tools. Why can't he go it 
alone? Well, he's usually 
operating on a small budget 
and thus can't mount any 
sort of larger marketing, 
packaging, or shipping effort. 
True, you might say, but 
couldn't he sell his product 
locally, at a neighborhood 
level? Yes, he could, but then 
he's not reaching the majority 
of people who are interested 
in his product, namely, us. 
Besides, how can he 
commercially support any 
product on even a medium 
scale, when such support 
might involve, aside from all 
the developmental and 


promotional work and 
expense, handling dozens of 
trouble reports in a single 
week? He'd no longer be a 
hobbyist, but a full time 
one-man software house, and 
that puts him out of the grass 
roots class. 

So, with our search ended, 
and no culprit in sight, what 
can be done about the 
software vacuum? 

First of all, those of us in 
the personal computing field 
who have professional 
contacts can urge existing and 
potential software vendors to 
look hard at the hobbyist 
markets. When the number of 
potential users of a package is 
multiplied by the profit 
margins to be expected, such 
software vendors should be 
economically viable. 
Whenever there is a demand 
for a product, a free market 
will tend to fill that demand. 
It will be interesting to see 
what the market produces in 


system software for small 
computers. 
Second, hobbyists can 


help generate commercial 
interest in this vital area in 
several ways. One is to make 
the software vacuum a topic 


for discussion at local 
computer club meetings. 
Another is to organize 


software trading posts in the 
newsletters which are very 
much a part of the hobby. 
Still another is to write 
manufacturers urging 
advanced software products 
to match the extremely high 
level of today's hardware 
technology. If you feel 
eloquent, write a letter to the 
editor of BYTE оп the 
subject. 

The first step in filling a 
need is identifying that the 
need exists. Hopefully these 
thoughts will start some 
BYTE readers off in a 
direction which will lead to 
commercially marketed mass 
produced software which can 
be plugged into one of the 
several microprocessor 
architectures which are on 
the market. ш 


Join now - 

Since 1947, ACM hs served as the educational and 
scientific society for "ies profesalonale 90, 000 
strong and growing. 


Write today 

. For.regular and student membership information 
send the attached coupon to ACM headquarters. With 
Special Interest Groups covering every major computing 
discipline. and local Chapters in most metropolitan areas, 
ACM is probably the organization you're looking for. 


Position : : ra Al | 


Association for Computing Machinery `` | 
1133 Avenue of the Americas, New York, N. Y. 10036 І 
| would like to consider joining АСМ, 

Please send more information. 

Name 


Address Е А ж. 


City -State Zip 


The MODULAR MICROS 
from MARTIN RESEARCH 


Here’s why the new M/KE 2 and MIKE 3 
are the best values in microcomputers to- 
day! 


8008 OR 8080 


Martin Research has solved the problem 
bothering many potential micro users 
.... Whether to go with the economical 
8008 microprocessor, or step up to the 
powerful 8080. Our carefully designed 
bus structure allows either processor to 
be used in the same system! 


The MIKE 3 comes with an 8080 CPU 
board, complete with crystal-controlled 
system timing. The M/KE 2 is based on 
the 8008. To upgrade from an 8008 to 
an 8080, the user unplugs the 8008 CPU 
board and plugs in the 8080 CPU. Then 
he unplugs the 8008 MONITOR PROM, 
and plugs in the 8080 MONITOR 
PROM, so that the system recognizes the 
8080 instruction set. That's about it! 


If the user has invested in slow memory 
chips, compatible with the 8008 but too 
slow for the 8080 running at full speed, 
he will have to make the 8080 wait for 
memory access—an optional feature on 
our boards. Better still, a 4K RAM board 


can be purchased from Martin Research , 


with fast RAM chips, capable of 8080 
speeds, at a cost no more that you might 
expect to pay for much slower devices. 


In short, the M/KE 2 user can feel confi- 
dent in developing his 8008 system with 
expanded memory and other features, 
knowing that his M/KE 2 can be up- 
graded to a M/KE 3—an 8080 system—in 
the future. 


EASE OF PROGRAMMING 


Instructions and data are entered simply 
by punching the 20-pad keyboard. Infor- 
mation, in convenient octal format, ap- 
pears automatically on the seven- 
segment display. This is a pleasant con- 
trast to the cumbersome microcom- 
puters which require the user to handle 
all information bit-by-bit, with a confus- 
ing array of twenty-odd toggle switches 
and over thirty red lights! 


A powerful MONITOR program is in- 
cluded with each microcomputer, stored 
permanently in PROM memory. The 
MONITOR continuously scans the key- 
board, programming the computer as 
keys are depressed. 


Say the user wishes to enter the number 
135 (octal for an 8008 OUTPUT 16 in- 


struction). He types 7, and the right- 


hand three digits read 007. Then he 
presses 3, and the digits say 073. Finally 
he punches the 5, and the display reads 
135. Notice how the MONITOR program 
(Continued in colunin 3.) 
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QUICK.... 


what number is this? 
eo oeo eoe 


If you have to read your microcomputer 
like this--bit by bit, from rows of lights--the 
computer's making you do its work. And if 
you have to use rows of toggle switches to 
program it, you might wonder why they 
call the computer a labor-saving device! 


Contrast the layout of a typical pocket 
calculator. A key for each number and 
function; six easy-to-read digits. Why not 
design microcomputers like that? | 


Here they are! The modular micros from 
Martin Research. The keyboard programs 
the computer, and the bright, fully- 
decoded digits display data and memory 
addresses. A Monitor programina PROM 
makes program entry easy. And, even the 
smallest system comes with enough RAM 
memory to get started! 


Both the M/KE 2 system, with the popular 
8008 processor, and the 8080-based MIKE 
3 rely on the same universal bus structure. 
This means that accessories--like our 450 
ns 4K RAM--are compatible with these 
and other 8-bit CPUs. And, systems start 
at under $300! For details, write for your... 


FREE CATALOG! 


MIKE 2 
MANUAL... 


This looseleaf 
book includes 
full information 
on the MIKE2 
system, with 
a schematics. 
Price for orders received 
by November 15, 1975... $19 
Includes a certificate worth $10 towards 
a modular micro system, good 90 days. 
(Offer valid, USA only.) After 11/15: $25. 


modular micros [У martin research 


Martin Research / 3336 Commercial Ave. 
Northbrook, IL 60062 / (312) 498-5060 


shifts each digit left automatically as a 
new digit is entered! The value on the 
display is also entered into an internal 
CPU register, ready for the next opera- 
tion. Simply by pressing the write key, 
for example, the user loads 735 into 
memory. 


The MONITOR program also allows the 
user to step through memory, one loca- 
tion at a time (starting anywhere), to 
check his programming. Plus, the Swap 
Register Option allows use of the inter- 
rupt capabilities of the microprocessor: 
the MONITOR saves internal register 
status upon receipt of an interrupt re- 
quest; when the interrupt routine ends, 
the main program continues right where 
it left off. 


We invite the reader to compare the pro- 
grammability of the MIKE family of 
microcomputers to others on the mar- 
ket, Notice that some are sold, as basic 
units, without any memory capacity at 
all. This means they simply cannot be 
programmed, until you purchase a mem- 
ory board as an “accessory.” Even then, 
adding RAM falls far short of a conve- 
nient, permanent MONITOR program 
stored in PROM. Instead, you have to 
enter your frequently-used subroutines 
by hand, each and every time you turn 
the power on. 


EASY 1/0 INTERFACE 


The MIKE family bus structure has been 
designed to permit easy addition of in- 
put and output ports. A hardware inter- 
face to the system generally needs only 
two chips—one strobe decoder, and one 
latching device (for output ports) or 
three-state driving device (for inputs). A 
new I/O board can be plugged in any- 
where on the bus; in fact, all the boards 
in the micro could be swapped around in 
any position, without affecting opera- 
tion. |/O addresses are easy to modify by 
reconnecting the leads to the strobe de- 
coder (full instructions are provided); 
this is in marked contrast to the clumsy 
input multiplexer approach sometimes 
used. 


POWER & HOUSING 


The micros described to the left are com- 
plete except for a cabinet of your own 
design, and a power supply. The basic 
micros require +5 V, 1.4 A, and —9 V, 
100 MA. The 4K RAM board requires 
5V, 1A. A supply providing these volt- 
ages, and £12 V also, will be ready soon. 


OPTIONS 


A number of useful micro accessories are 
scheduled for announcement. In addi- 
tion, the MIKE 3 and MIKE 2 may be 
purchased in configurations ranging from 
unpopulated cards to complete systems. 
For details, phone, write, or check the 
reader service card. 


YTE’S 


ITS 


The Secret of Unraveling Wire Wrap Boards 


A lot of home brew 
computer people are 
obtaining surplus printed 


circuit cards and back planes 
that have been wire wrapped. 
In order to use the 
components from such 
boards the wires must be 
carefully pulled off the 
wrapping posts. Without a 
special tool it is difficult to 
remove wire while preserving 
the integrity of the delicate 
wrapping posts. Since many 
BYTE readers do not have 
the commercial dewrapping 
tools, removal of wire is for 
them a nasty and time 


consuming job at best. 
| have devised a simple 


much easier, made from items 
normally found around a well 
equipped workshop. The 
tool, shown in Fig. 1, is 
constructed from a paper clip 
and a drapery hook. Simply 
follow the instructions. 

1. Obtain a standard 
paper clip, an Exacto knife 
holder, and a thin sharp 
pick of sorts, such as a 
drapery hook. 

2. Bend the paper clip 
and drapery hook as shown. 

3. Place the paper clip in 
the Exacto blade holder. 
Now you are ready to 
dewrap. 

4. Using the pick, flick 
the wire from the post at 


Ud - 


5. Place the paper clip bit 
onto the wire wrap post and 
slip it down until the end of 
the paper clip is just past 
the wirc. 


6. Rotate the blade 
holder in the direction 
which unravels the wire 


Fig. 1. A homebuilt tool to loosen 


and remove wire wrapped 
connections. 
by 


Richard J. Lerseth 
8245 Mediterranean Way 


which makes this task least an eighth of an inch. until thc entire wire is loose. Sacramento CA 95826 


USE OUR HARDWARE ASSEMBLERS\ 


SAVE TIME AND FRUSTRATION WITH THESE CONVENIENT PRINTED CIRCUITS О 


tool 


4096-BY TE MEMORY MATRIX MACRO CARD 

Have.you ever wanted to construct a memory matrix as part of a system?? The tedious part is the interconnection of all the address and 
data bus pins! The CDA-1.1 memory matrix is a general purpose memory prototyping card for the 2102/2602/9102 pinout static RAM 
chips. This PC card is 8'"x10'' with 70 pin edge connector, gold plated for reliability. The memory matrix occupies about 60% of 
available area with all lines brought out to pads for wire-wrap pins and has plated-through holes. The other 40% has 24 16-pin socket 
positions and a general purpose area which can hold 12 16-pin sockets, or 4 24-pin sockets, or 2 40-pin sockets. Add a custom wired 
controller to interface this board's memory matrix to any computer, or use the prewired matrix as the basis for a dedicated 4K by 8 
memory in a custom system. Think of the time you save!! 
GENERAL PURPOSE PROTOTYPING CARD 

The CDA-2.1 general purpose 8'x10' prototyping card comes predrilled for use in construction of custom circuits. This board 
accommodates 16-pin sockets plus has a general area for 16-pin sockets or 24 or 40 pin sockets. The 70-pin edge connector is gold-plated 
for reliability and the pins are brought to pads for wire-wrap post insertion. The socket side has a solid ground plane to minimize noise 
problems; busses on the wiring side allow short jumper connections for power and ground. A whole system may be constructed in 
modules with these boards. 

DIGITAL GRAPHIC DISPLAY OSCILLOSCOPE INTERFACE, CDA-3.1 

James Hogenson (see the October issue of BYTE magazine) designed a 64x64 bit-matrix graphics display for oscilloscope. This design 
permits use of your scope as a display for ping-pong, LIFE, or other games with your system. The CDA 3.1 card pravides all the printed 
wiring needed to assemble the graphics display device down to the TTL Z-axis output as described in October 1975 BYTE. To complete 
the display you merely add components to this double sided card with plated-through holes. 

For info: CIRCLE READERS’ SERVICE NUMBER — or, send your order using the coupon below: 


FROM: 
NAME 
ADDRESS 


Y ES | Please rush me the boards ordered below: 


[] 4096-8 YTE MEMORY MATRIX PROTOTYPING 


CARD at $39.95 
GENERAL PURPOSE PROTOTYPING CARD AT 


$29.95 
DIGITAL OSCILLOSCOPE GRAPHIC DISPLAY 
CARD AT $29.95 


CELDAT DESIGN ASSOCIATES 


P.O. BOX 752 
AMHERST, N.H. 03031 


g I’ve enclosed a check or money order for 
$___s~Foreign orders (except Canada) please 
add $2 postage per card. 


Please allow four weeks for delivery — you must be fully satisfied or your money will be cheerfully refunded. 
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HI-SPEED 
STATIC RAM 2602-1 475 пѕ 


Manufactured by Signetics, 2102 pinout 
$4.25 for 1/$4.00 each for 8/$3.75 each for 32 
WHY PAY FOR BEING SMALL? 


Centi-Byte is a new source of memory components 
and other necessary items for the computer hardware 
builder. Centi-Byte’s function is to be a voice to the 
manufacturing companies representing you, the modest 
volume consumer of special purpose components. Centi- 
Byte brings you this special introductory offer of fast 
memory chips, chips fast enough to run an MC6800, 
MCS6501 or 8080 computer at maximum speed. These 
2602-1's are new devices purchased in quantity and fully 
guaranteed to manufacturer's specifications. 

Centi-Byte works by concentrating your purchasing 
power into quantity buys of new components. Let me 
know what you need in the way of specialized com- 
ponents and subsystems for future offerings. With your 
purchasing power concentrated through Centi-Byte we'll 
help lower the cost of home computing. 


All orders are shipped postpaid and insured. Massachusetts 
residents add 3% sales tax. 


Car! M. Mikkelsen, Proprietor, P.O. Box 312, Belmont MA 02178 


Hidden in the matrix are 96 words and abbreviations associated with 
computers in one way or another. Find a word, circle it or color it in, 
and cross it off the list. Words may be forward, backwards, up, down, 
or diagonal, and are always in a straight line, never skipping letters. 
However, some letters are used more than once. After circling all the 
words on the list, the unused letters (14 total) will spell out a secret 
message. Beware: Some buzzwords occur in the matrix, but are not on 
the list! 


Good luck and good hunting. . . it may take a while! 
ACCUMULATOR CHIP FOCAL 
ADD (not in address) CLOCK FORMAT 
ADDRESS COBOL FORTRAN 
ALPHANUMERIC COUNTER GATE 
AND DATA GLOBAL 
APL DEBUG HALT 
ASCII DESTINATION INPUT 
ASSEMBLER DEVICE INSTRUCTION 
ASYNCHRONOUS DIAGNOSTIC INTERFACE 
BASIC DIODE INTERRUPT 
BATCH DISK JUMP 
BAUD DISPLAY LED 
BCD DTL LINK 
BET ECL LIST 
BINARY EXECUTE LITERAL 
BOOLEAN EXIT LOAD 
BRANCH FALSE LOCATION 
BUFFER FETCH LOG 
BYTE FILE LOOP 
CHECKSUM FLAG LSI 
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MATRICES 
MEMORY 

MHZ 

MICROCODE 
MICROPROCESSOR 
MNEMONIC 

MOS 

OCTAL 

PCB 

PERIPHERAL 
PLOT 

POINTER 
PRIORITY 
PROGRAM 

PROM 

QUEUE 

RAM (not in program) 
READ 

RECORD 

ROL 


WORD HUNT 
BETEC 


R TRAN 


IAE 


SOURCE 


STACK 
STATUS 
STORAGE 
SUBROUTINE 
SUBSYSTEM 
SYNTAX 
TABLE 
TRANSMITTER 
TRAP 

TTL 

vcc 

VECTOR 
VERIFY 
WIRE 

WORD 


subseribe to COMPUTER... 


te 


AX 


automatically 


. . . With a membership in the IEEE Computer Society. 


Special offer 
‘to BYTE readers 


You can join the Computer Society 

now... апа receive a free copy of 

Microprocessor Architecture and 

Applications — in addition to your Microprocessor Architecture & Applications 


$ Ж #1 The Computer July and August 74 issues 
automatic subscription to COMPUTE R. focussed on microprocessor architecture and 


applications. The feature articles have been 


Write to us at the address below (be reprinted and bound into à single volume, 


covering such topics as present and future 


sure to refer to this announcement), microprocessors, a home-school micro- 
and we'll tell you about one of the processor system, the use of microprocessors 
as automohile on-board controllers, and a 


wisest investments you'll ever make in microprocessor-controlled electronic 
your professional career. distance meter. Regular price: $3.50 


5855 Naples Plaza • Suite 301 • Long Beach, California 90803 • Telephone (213) 438-9951 


Logic Probes - 
Hardware Bug Chasers 


by 

Alex. F. Burr 

Physics Dept. Box 3D 

New Mexico State University 
Las Cruces NM 88003 


While an oscilloscope or 
voltmeter can be used with 
digital circuits, a logic 
probe is much less 
expensive if built from an 
appropriate kit. 
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Digital logic, whether used 
in an 8080 microprocessor or 
as the TTL chips that can be 
used to make a processor, is, 
at least in theory, clean and 
simple because only two 
states are possible. Any point 
in even the most complicated 
circuit is either HIGH or 
LOW. However this very 
simplicity encourages the 
design of large and 
complicated circuits. While 
the chance of anything going 
wrong at any one point is 
small, the accumulated 
chances of тапу points 
means that sooner or later the 
experimenter is going to have 


to hunt for sources of 
trouble. 

In the case of analog 
circuits, when trouble 
develops, you get out the 


oscilloscope or voltmeter and 
start looking for places which 
have waveforms or voltages 
not meeting the 
specifications. These 
instruments can be used to 
troubleshoot digital circuits 
too. The oscilloscope is 
particularly useful if you have 
timing problems, but usually 


they give you too much 
information and may just 
confuse the issue. The 


voltmeter may tell you that 
the voltage on pin 8 is 3.9 
but, because most IC failures 
show up as a node stuck 
either HIGH or LOW, really 
all you need to know is that 
on pin 8 there is a HIGH. 
That single bit (literally) of 
information can be obtained 
with an instrument a lot 
smaller and less complicated 
than a voltmeter. 

That instrument is the 
logic probe. |n its simplest 
form it is just a state 
indicator with a sharp point. 


AAi 


SEE PULSE STREAMS 


s S 
SEE 
SINGLE-SHOT 
RESPONSES... 


INTERNAL 
SHORT-—-—— 


When the point is placed on 
any pin of an IC, the probe 
will indicate whether a LOW 
or a HIGH is present at that 
point. And with digital logic 
that is usually all the 
information you need. 

Logic probes can detect a 
surprising number of 
different defective 
conditions. Fig. 1 illustrates 
some of the uses to which a 
probe can be put. Of course, 
just as voltmeters come with 
a variety of capabilities and 
prices, so do logic probes. 


TULS - 
SEE PULSE STREAMS 


SEE OPEN CIRCUITS 
j —-OPEN BOND 


SOLDER 
_ BRIDGE 


SEE STUCK 
LOWS 


EE ee 
SEE LOW REP RATE 
HIGHS AND LOWS 


—— NM 
SEE SINGLE-SHOT RESPONSES 


Fig. 1. Some of the uses of logic probes and the malfunctions which 


they can detect. 


Commercial Logic Probes 


One of the first developed 
was the Hewlett Packard 
10525T logic probe. It is a 
marvel of compactness and 
versatility, all carefully 
human-engineered. Basically 
it consists of a white light 
which goes out when the 
probe is placed on a LOW and 
comes on when the probe is 
placed on a HIGH. 

Simple -- yes indeed; but 
it does much more. What if 
the point tested is open 
circuited, or the level is just 
plain bad, neither HIGH or 
LOW? Then the light glows 
at half intensity. What if a 
pulse comes along that is too 
short to excite the indicator 
light? Then a pulse stretcher 
takes over. Pulses with a 
width of between 10 ms and 
0.05 seconds are stretched to 
0.05 seconds in length. What 
if the pulses come so fast that 
the eye cannot distinguish 
one from the next? All pulse 
streams with a repetition rate 
between 10 Hz and 50 MHz 
cause the lamp to blink at a 
10 Hz rate. All this capability 
is enclosed in a probe about 
six inches long and one-half 
inch in diameter. The light is 
placed near the tip in such a 
way that it can be seen no 
matter how the probe is 
rotated. Thus you can easily 
see both the point of the 
probe and the indicator at the 


— 


ГЕ 


The Е & L Instruments logic probe is compact, with the two indicator LEDs visible toward the 


left in this photo. 


same time. Power is supplied 
to the probe by a well 
protected single cord which is 
attached to a source of 5 V 
dc at 60 mA. 

The input impedance is 
greater than 25k Ohms in 
both the HIGH and LOW 
state (less than one low 
power TTL load). The input 
is well protected against 
operator error. The probe will 
stand +70 volts continuously 
and +200 volts intermittently 
as well as 120 V ac for 30 
seconds. The power input is 
internally protected from +7 
to —15 V dc as well as power 
lead reversal. The only catch 
is the price, which even with 
a recent reduction is $65. 

There are, however, other 
less expensive probes. T wo of 


these are distributed by E and 
L Laboratories. Their model 
340 is a logic probe and 
pulser combined into one 
instrument. The model 320 is 
a logic probe only, designed 
to give maximum information 
about the state of the node 
being tested. Both probes are 
well constructed, a little over 
6 1/2 inches in length and 
half an inch in diameter. Both 
come with two different 
probe tips and handy carrying 
cases. 

The model 340 has two 
LED indicator lights. In 
operation the two leads from 
the probe are connected to 
the 5 V dc supply and the 
probe tip applied to the IC 
lead to be tested. If that node 
is HIGH, the red LED lights 


The Hewlett Packard 10525T logic probe and 10526T pulser. 


up brightly. If that node is 
LOW, neither LED is lit. The 
green LED is used to detect 
pulses which do not last long 
enough to give a useful 
indication on the red LED. It 
lights for 0.1 seconds (just 
long enough to see) whenever 
a single pulse wider than 50 
nanoseconds is applied to the 
probe tip. In the probe tested 
for this article, when a 
voltage increasing from zero 
was applied to the tip, the red 
LED lit when the voltage was 
greater than 1.5 V; just what 
the specifications called for. 

The model 320 is a little 
more versatile as an indicating 
instrument, but it lacks the 
ability to generate pulses that 
the model 340 has. It too has 
two LED indicators, one red 
and one green. In operation, 
the two power leads are 
connected to the 5 V dc 
power supply and the tip to 
the node under test. The 
specifications say that if the 
voltage at the node is less 
than 0.7 volts the green LED 
will be lit. 1f the voltage is 
greater than 2.4 volts, the red 
LED will be lit. In practice 
the specifications are closely 
followed. The LEDs may 
glow dimly at voltages just a 
few tenths higher or lower 
than the specified voltages. 
But the dividing line between 
lit and not lit states is 
remarkably sharp. 

A special feature of this 
probe is the pulse storage 
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“Nodes” are places in a 
circuit — such as the pin of 
an 1С — where you might 
want to test the logic level 
using the probe. 


TO GROUND CLIPO 


TO 5V CLIP O 


TO PROBE TIPO 


capability brought into play 
by a small switch near the tip. 
When the pulse storage 
feature is on, a short pulse 
(either HIGH or LOW) is 
stretched so that it turns on 
the appropriate LED to full 
brightness even if it is as short 
as 50 nanoseconds. Square 
and sine waves appearing at a 
tested node will cause both 
LEDs to have equal 
brightness. 

The main difficulty noted 
with this probe is with the 
green LED. It is somewhat 
dimmer than the red LED 
and the lens diffuses the spot 
of light generated less well so 
that in bright room light it is 
sometimes hard to tell 
whether or not the green 
LED is lit. This fact would 
make the determination of 
the duty cycle of a chain of 
pulses by a brightness 
comparison between the 
LEDs much more difficult 
than the instruction booklet 


suggests. 

Even the E and L 
Laboratories probes are 
expensive ($35 and $25); 
although they are more 
convenient than, and 


certainly in the same price 


Q 
TO GROUND CLIP 


Fig. 2. Circuit diagram for the James logic probe kit. 
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range as, a good voltmeter. 
Nothing, however, can beat 
the cost effectiveness of two 
probe kits which have been 
fairly widely advertised. 


Logic Probe Kits 


One of these kits is 
manufactured by Chesapeake 
Digital Devices. This kit 


allows one to easily construct 
a probe which uses red, green 
and yellow LEDs to signal the 
presence of logic levels in 
digital circuits. 

The kit goes together in a 
very short time with the aid 
of very complete assembly 
instructions. The whole probe 
fits into a well constructed 
case, a little over six inches 
long and slightly less than one 
inch in diameter. There are 
only three resistors, three 
LEDs, one transistor, and a 
74S00 integrated circuit to 
solder onto the clearly 
marked printed circuit board. 

In operation the green 
LED is brightly lit on a LOW, 
the red LED is brightly lit on 
a logic HIGH, while the 
yellow LED lights on an open 
circuit or a level between a 
true HIGH or LOW. A slow 
pulsing condition will be 
indicated by alternate 
flashing of the red and green 
LEDs. A fast pulsing 
condition will be indicated by 
the simultaneous activation 
of the red and green LEDs. 
The dividing line between 
these last two conditions is 
about 20 Hz, depending on 
the eye of the user. 

The biggest difficulty with 
the kit was the circuit board. 
The copper leads had not 
been tinned and were 
oxidized, making them a bit 
difficult to solder; especially 
if the builder was concerned 
that he not use so much heat 
for so long as to damage the 
components. The clear plastic 
tube into which the circuit 
board with its LEDs slide did 
crack on assembly and the 
green LED was open but 
these difficulties were easily 
remedied and the result was a 


handy logic probe at a price 
significantly less than any 
assembled probe. 


A Unique Probe 

A particularly inexpensive 
kit is the one sold by James 
Electronics for $9.95 
including postage and case. It 
is unique in that it uses a 
MAN 3 seven segment 
readout which gives a 1 for a 
HIGH a 0 for a LOW anda P 
for a pulse train — all this іп a 
compact package measuring 
five inches long and one inch 
in diameter. 

The circuit diagram for 
this intriguing probe is given 
in Fig. 2. The 2N2222 input 
transistor drives the chip, 
IC1, which in turn causes the 
appropriate segments of the 
MAN 3 to light. The chip was 
custom made "for james 
Electronics b National 
Semiconductor and contains 
a proprietary circuit. which 
master mask. 

The kit comes in a very 
impressive package which was 
carefully designed to protect 
the contents from rough 
handling by the U.S. Postal 
Service. The parts, which 
include the case and a custom 
glass epoxy printed circuit 
board, are of high quality and 
are not your usual cheap 
imports. Because most of the 
parts are in the 14-pin chip 
which is the heart of the 
probe, the kit goes together 
quickly and easily for the 
experienced builder (about 
one hour to solder all the 
parts to the board). There are 
no explicit devices for 
overload or reverse voltage 
protection. The probe draws 
65 mA from any convenient 
5 M point on the circuit 
under test. 

The inexperienced builder 


is going to have trouble 
because the complete 
assembly instructions say, 


"Assemble the Logic Probe 
according to the schematic 
diagram and board layout 
shown below." The end. One 
has to have pretty sharp eyes 


A kit logic probe shown in action testing a printed circuit board. 


to orientate the IC, transistor 
and readout correctly. Even 
then you might miss the two 
jumpers that go on the circuit 
board. The circuit board also 
could have been laid out 
more efficiently so that 
the drastic bending of the 


MAN 3 leads would have 
been avoided. 

There is опе serious 
defect. It is more serious 


from the theoretical than the 
practical point of view. That 
defect concerns the input 
level at which the indicator 
switches from O to 1. That 
level is 0.65 volts; but the 
specifications for TTL logic 
say that the maximum 
voltage that the logic is 
guaranteed to interpret as 
LOW is 0.8 volts. Thus the 
probe would indicate a HIGH 
on a node which the logic 
would interpret as a LOW. 
This defect is of lesser 
practical importance because 
it is the unusual LOW which 
will have a voltage greater 
than 0.6 V. Indeed the usual 
gate input is only a very few 
tenths of a volt above ground 
at the most when it is LOW. 
Nevertheless it is a bit 
disconcerting to have the 
probe give a wrong reading 


even if it does so only under 
unusual circumstances. After 
all, it is under unusual 
circumstances that the probe 
is most often used. 


Logic Clips? 

The probes which have 
been discussed so far all 
investigate one pin of the IC 
at a time. There are some 
instruments which will do 
much more. These are called 


logic clips and are not really 
probes but will give you the 
same type of information. 
They are extremely handy 
service and design tools. They 
clip onto TTL DIP ICs and 
instantly display the logic 
states of all 14 or 16 pins. 
Each of the clip's 16 LEDs 
independently follows level 
changes at its associated pin: 
A lighted diode corresponds 
to a HIGH. 


A logic clip is like 16. 
binary voltmeters in a neat 
little package. 


The logic clip's геа! value 
is in its ease of use. It has no 
controls to set, needs no 
power connections, and 
requires practically no 
explanation as to how it is 
used. The clip has its own 
gating logic for locating the 
ground and +5 volts Vcc pins 
and the buffered inputs 
reduce circuit loading. Simply 
attaching the clip to a TTL 
dual inline package makes all 


A detail of the Chesapeake Digital Devices logic probe board. The three LEDs are at the right in 
this picture, with the 74S00 IC in the center. 
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Notes: 


the logic states visible at a 
glance. The clip is, in effect, 
16 binary voltmeters. When 
used with some means of 
pulsing a complicated circuit 
slowly, sequential logic states 
like shift registers come alive 
— each state change is 
immediately visible. 

The most popular clips are 
made by Hewlett Packard and 
Circuit Specialties. 
Unfortunately they have one 
big drawback — price. They 
cost from $75 to $85 each 
and will not be discussed 
further here. 


Summary 


Table 1 summarizes all the 
information that has been 
given here and presents some 
new facts about each of the 
logic probes discussed. By 
scanning this table you ought 
to be able to determine which 
probes have the features you 
need and the ones you can 
afford. The following 
comments are based on 
personal experience with each 


Table 1. Characteristics of logic probes. 


Probe 


Operating 
Voltage 


Current 


Frequency 
Response 


Input Impedance 
Min. pulse width 
Levels OPEN 
HIGH 
LOW 
Size 


Overvoltage 
protection 


Price 


HP 10525T! 3402 
Б 10% \/ 


5+ 10% V 


60 mA 


БО MHz 


>25 ко 

10 ms 

half intensity 
on > 240.2 V 
off <0.8 M 
6" x 0.5" dia. 


excellent 


$65 


!Hewlett Packard, Palo Alto CA 94304. 
2Е and L Instruments Inc., 61 First St., Derby CT 06418. 


3Chesapeake Digital Devices, Inc., Box 341, Havre de Grace MD 21078. 
4 James Electronics, Box 822, Belmont CA 94002. 


100 mA 


12 MHz 


50 ко, 
50 ms 
no lights" 


red 21.5 V 


no lights 


6.6" x 0.6” dia. 


reasonable 


$358 


SPulse trains faster than 10 Hz cause the lamp to flash at a 10 Hz rate. 


6Pulses between 10 ms and 0.05 seconds are stretched to 0.05 seconds. 
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of these probes, but that 
experience has been rather 
limited. 

The Hewlett Packard 
probe is obviously the best. It 
should be; it certainly costs 
significantly more. lt will 
work under a wide range of 
conditions and it is carefully 
made. For the extra money 
you get wide frequency 
range, tight specifications, 
and vastly superior handling 
of pulse trains. The 
construction is first class and 
includes such extras as a 
compact BNC plug on the 
power cable (which, of 
course, is not so good if your 
breadboarding system does 
not have a BNC jack to 
supply that power). 

The E and L probes (340 
and 320) are imported from 
Japan. They are very well 
constructed and have the 
little extras like plastic 
carrying cases and different 
probe tips that the better 
Japanese manufacturers like 
to include with their 


products. The 320 is a better 
logic probe than the 340. It is 
less expensive and it handles 
pulse trains and logic levels in 
a better and more revealing 
way. Of course, it does not 
have the pulse generating 
capabilities of the 340. 

The professional logic 
designer will want to get onc 
of these three probes. They 
may be a bit expensive for 
the serious hobbyist. In that 
case one of the two kits 
would be satisfactory. 

Both kits went together 
easily and rapidly. The CDD 
kit is much more revealing 
about the state of the logic 
under test and has superior 
assembly instructions. The 
James kit has better quality 
parts and is cheaper. 

In any case the serious 
worker in digital logic and 
computers, whether a 
professional or а serious 
hobbyist, will find one of 
these probes a valued 
addition to his collection of 
test equipment. m 


3202 сор? 


5+10% \/ 


80 mA 


12 MHz 


100-600 к? 
50 ms 
no lights? 

red >2.4V 
green <0.7 V 
6.6" x 0.6" dia. 


reasonable none 


$25 $1512 


40 тА 


yellow 
red >2.5V 
green «1v 


6" x 1" dia. 


5 * 10% V 


See 1 


1202 V 
0<07 V 
5 x 1" dia. 


none 


$1012 


"Short pulses indicated by green LED. 


8single pulse generator contained in probe. 


9Switchable pulse stretcher for short pulses. 
10уецоу LED is also lit if voltage is between HIGH and LOW. 
llindicator reads P for pulse trains > 20 Hz. 


12ки price. 


R ELECTRONICS 


DISCOUNTS: 10% OFF ORDERS OVER $25.00; 20% OFF ORDERS OVER $250.00. 


ANOTHER POWER SUPPLY... 


PS 25—1 0 to 25v 1a lab type power supply with adjustable current 
limiting; remote sensing & remote programming for voltage & current. 
Insturctions included. All parts except chassis, meter(s), p.c. board. 
Kit of parts with schematics. $14.95 
P.C. boards available, No. 007 $3.00 ea. 


SPECIAL 
1808 $50 
8-2102 


2K RAM BOARD KIT. ALL 
PARTS INCL. SOCKETS 


$84.50 


ICs 


8008 MICROCOMP. CHIP$30.95 
2102 1K STATIC RAM 3.00 
5203 256x8 PROM 15.00 
5204 512x8 PROM 25.00 


INFO ON ABOVE CHIPS IF 
ASKED FOR. 


008A MICROCOMPUTER KIT 


8008 CPU, 1024 x 8 memory; memory is expand- 
able. Kit includes manual with schematic, program- 
ming instructions and suggestions; all [Cs and parts 
supplied except cabinet, fuses & hardware. Includes 
p. c. boards. $375.00 

MANUAL ONLY, $25.00 
(no discount on manual) 


ORDERS OF $50 OR 
MORE GET FREE BYTE 
SUBSCRIPTION IF ASKED 
FOR (CONTINENTAL U.S. 
ONLY). 


008A-K ASCII keyboard input kit. $135.00 


008A-C Audio cassette adapter kit. $100.00 


Details on computer, peripheral kits in our flyer. 


RGS ELECTRONICS | 
3650 Charles St., Suite K = Santa Clara, CA 95050 m (408) 247-0158 


We sel! many ICs and components not listed in this ad. Send a stamp for our free flyer. TERMS OF SALE: 
All orders prepaid; we pay postage. $1.00 handling charge on orders under $10.00. California residents please 
include sales tax. Please include name, address and zip code on all orders and flyer requests. Prices subject to 
change without notice. 
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circuit by 

John Errico 

5 Richard Rd. 
Hudson MA 01749 


written by 

Robert Baker 

34 White Pine Dr. 
Littleton MA 01460 


owerless IC 
Test Clip 


This test clip operates like 
the expensive, commercially 
available clips selling for $85 
or more without requiring 
batteries or external power. 
All types of ICs may be 
tested (TTL, DTL, MOS, etc.) 
and LEDs are used to indicate 
the logic state of each pin 
being tested. 

The heart of the test clip is 
a Texas Instruments TID125 
diode array which costs about 
$3.75. Two diode arrays are 
used to determine the pin 
with the highest voltage (Vcc) 
and the pin with the lowest 
voltage (ground). These pins 
are then used to power the 
LEDs on the test clip itself, 
thus taking power from the 
IC on the board and 
eliminating the need for an 
external or separate supply. 
The circuit is straight forward 
and may be expanded to 
make a 24- or 40-pin test clip. 
The larger test clip, however, 
may be difficult to use due to 
the size of the LED display. 

The basic IC clip is a 
standard item available from 
AP Products Inc., Box 110-Z, 
Painesville OH 44077. The 
16-pin clip is part number 
923700 (TC-16) and sells for 
$5.75 each. 


The diode arrays are 
14-pin dip packages and were 
chosen to make the test clip 
more compact. To cut down 
the cost, 16 general purpose 
silicon diodes may be used in 
place of cach diode array IC. 
The transistors used to drive 
the LEDs may be any NPN 
transistor capable of handling 
the LED current. Any small 
size LED may be used; 
however, the 1k resistance 
value may have to be 
changed. Choose a value 
which gives about 2 mA 
current through the LED; this 
should give sufficient 
brightness without loading 
down the circuit supply. 

Construction is very 
simple and parts layout is not 
critical. Use a small piece of 
0.1" grid perforated board 
bolted to each side of the IC 
clip to mount components 


on. Try to keep the overall 
physical size of the boards as 
small as possible to make the 
finished test clip easier to 
handle. The LEDs should be 
mounted along the top edge 
of the perforated boards so 
they are visible from above 
the clip when it is attached to 
an IC. | would suggest 
wrapping a small piece of 
dark tape or using a short 
piece of dark tubing around 
each LED to improve 
visibility of the finished LED 
display. One of the TID125 
diode arrays is mounted on 


each piece of perforated 
board along with the 
associated  resistors and 


transistors, positioned 
wherever convenient. 
Remember to run two wires 
between the two perforated 
boards to connect the Vcc 
and ground outputs of the 


TIDI25 DIODE ARRAY 


diode arrays together. These 
wires should be stranded to 
withstand the movement of 
opening and closing the test 
clip when in use. 

Using the test clip is the 
simplest part of all. Just clip 
it over the desired IC. Don’t 
worry about how to position 
the test clip on the IC; pin 1 
may be at either end and the 
test clip will still work 
properly. With the test clip 
installed on an IC package the 
LEDs will indicate the logic 
level of each pin: 


ON = Logic 1 (HIGH) or Vcc 


pin 
OFF = Logic 0 (LOW) or 
ground pin 


On 14-pin ICs disregard the 
two pins not attached. 

Who said building an IC 
test probe is hard? m 


n ee "li у 
| | cc 
| : | 
| | 
| | 
| | 
| m 
GND 
L_ 22 _ 
r=- 7 {2 
| 
| ; 5 | | |] | [| — | [ — | 
i зо! [| ] l1 T | 
! 46 у Г ST ee 
lg 5 o ИШЕ ШШ ИШИН 
| 1 6 o- и 
|Р то uuum 
la 8 07 
1 3 o | 
Ф 
le no | 
18 wo! | | | 
Г з с ИШЕ ШШШ ШНА 
EST || ] а 
1 воі __ l1 L| L 3j 
| воі | ] l l|] 1 lI  ] 
| | 
L---- ——- T Bc 
[ n 
| Vec 
| | 
| 
| | 
| 
| | 
| | 
| m 
| GND 


TIDI25 DIODE ARRAY 


ONE LED DRIVER 
CIRCUIT REQUIRED FOR 
EACH PIN 


Vec 
IK 
2K 2N3904 
OR 
EQUIV. 
MV5054 —2 
OR 
EQUIV. LED 
GND 


ALL RESISTORS = 1/8 WATT 
CONNECT ALL V. PINS 


TOGETHER & ALL GND 
PINS TOGETHER 


Fig. 1. Powerless IC Test Clip. 
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8800 HARDWARE! 


BUILD A SMART TERMINAL INTO YOUR 
ALTAIR! Your Altair 
already hus the intelligence, we provide the display 
module. This module is not a limitied “TV Typewriter” 
but an ultra-high speed computer terminal built into 
your computer. The VDM-1 generates sixteen 64 charac- 
ter lines from data stored in the IK byte on-card 
memory. Alphnumeric data is shown in a 7x9 dot matrix 
format with a full 128 upper and lower case ASCII 
character set. The VDM-1 features EIA video output for 
any standard video monitor, multiple programmable 
cursors, automatic text scrolling and powerful test 
editing software included FREE! Available now. 


!! MASS STORAGE !! 

We have always wanted a low cost, reliable, fast access 
storage device using standard Phillips cassettes (we bet 
you have too), so we got to work and designed one 

here it is! With the CDS-VIII Cassette Data System you 
have computer controlled access to 128K bytes of data 
within 20 seconds when using C-30 cassettes. We provide 
read/write electronics and transport controller, Altair 
interface, a case and power supply, and one or two 
multiple motor cassette. transports plus FREE driving 
software! Yes, up to two cassette drives! Two drives 
provide much more powerful file handling and vopying 
capabilities as well as, of course, twice the storage 
capacity. Data can be written and/or read asynchronous- 
ly at any transfer rate up to 150 bytes/sec: at this rate 
8K BASIC can be loaded in about 50 seconds! We have 
also included provision for use of any read/write 
electronic plugin section so that tapes using UIT, 
Computer Hobbyist or Digital Group formats may be 
read at lower data rates. Available in November 19785. 


4KRA Static Read/Write Memory 


This 4096 word STATIC memory provides faster, more 
reliable and less expensive operation than any currently 
available dynamic memory system. The 4KRA permits 
Altair 8800 operation at absolute top — speed 
continuously. All RAM's (Random Access Memories) 
used in the 4KRA аге 9ILO2A's by Advanced Micro 
Devices, the best commercial memory IC on the market 
today. 91L02A's require typically 1/3 the power of 
standard 2102 or 8101 type RAM's and each one is 
manufactured to military specification MIL STD-883 for 
extremely high reliability. These memories can be 
operated from a battery backup supply in case of power 
failure with very low standby power consumption. (Ask 
for our technical bulletin TB-101 on power down 
operation.) In short we have done everything we could 
to make the best 4K memory module in the computer 
field, and because we buy in large quantity, we can make 
it for a very reasonable price. Available now. 


2KRO Erasable Reprogrammable 
Read Only Memory Module 


With this module the Altair 8800 can use 1702A or 
5203 type Erasable Reprogrammable ROM's. The 2KRO 
accepts up to eight of these IC's for a capacity of 2048 
eight bit words. Once programmed this module will hold 
its data indefinitely whether or not power is on. This 
feature is extremely useful when developing software. 
All necessary bus interfacing logic and regulated supplies 
are provided but NOT the EPROM IC's. Both 1702A 
and 5203 PROM's are available from other advertisers in 
this magazine for well under $25. Available now. 


We have Altair compatible plug-in peripherals! 


3P+S Input/Output Module 


Just one 3P+S card will fulfill the Input/Output needs of 
most 8800 users. There are two 8-bit parallel input and 
output ports with full handshaking logic. There is also a 
serial ЏО using a UART with both teletype current loop 
and EIA RS-232 standard interfaces provided. The serial 
data rate can be set under software control between 35 
and 9600 Baud. You can use your oid model 19 TTY! 
This module gives you all the electronics you need to 
interface most peripheral devices with the Altair 8800, 
it’s really the most useful and versatile [/O we've seen 
for any computer. Available now. 


MB-1 Mother Board 


Don't worry any more about wiring hundreds of wires in 
your Altair to expand the mainframe. Our single piece 
1/8-inch thick, rugged mother board can be installed as 
one single replacement for either three or four 88EC 
Expander cards, so you don't have to replace your 
already installed S8EC card if you don't want to. The 
МВ-1 has very heavy power and ground busses and 
comes with a piece of flat ribbon cable for connection to 
the front panel board of the 8800, a built-in bus termi- 
nator, and card guide cage for sixteen plug-in slots. 
Available now. 


PRICE LIST effective Oct. 1, 1975 


Item Kit Assembled Delivery 


2KRO EPROM module S 50. 5$ 75, 3 weeks max. 
3P+S ЏО module 125. 165. 3 weeks max. 
AKRA-2 RAM module w/ 
2048 8-bit words 
4KRA-4 RAM module w/ 
4096 8-bit words 

RAM only, AMD9ILO2A 
500 nsec, LOW POWER 
CDS-VIII-1 Cassette Data 
System w/one transport 
CDS-VIII-2 w/two trans- 


WRITE FOR DETAILS 
WRITE FOR DETAILS 
8/$40. - 


3 weeks max. 


WRITE FOR DETAILS 


ports WRITE FOR DETAILS 

MB-I Mother board, bus 

lerminator, card cage 70. - 3 weeks max. 
VDM-1 Video Display 

module 160. 225. 3 weeks max. 


TERMS: All items postpaid if full payment accompanies 
order. COD orders must include 25% deposit. 


MasterCharge gladly accepted, but please send us an 
order with your signature on it. 

DISCOUNTS: Orders over $375 may subtract 575; orders 
over $600 may subtract 10%. 


| Processor Technology 
2465 Fourth Street 
Berkeley, Ca.94710 


(415) f Berkeley, 0857 


8800 SOFTWARE! 


WE HAVE ALTAIR COMPATIBLE 8080 SOFTWARE AND FIRMWARE MODULES! 


If you haven't used our Assembly Language Operating System you have been missing 
a wonderful experience. We have found the ALOS Resident Editor and Assembler to be 
an extremely useful and powerful program development tool. We are so sure you will be 
turned on with our Software Package No. 1 that we are practically giving a listing away for 
a mere $3.00US. Yes, this is a source listing as well as a hexidecimal printout. 


The Assembly Language Operating System gives you the ability to write programs in 
8080 Assembly Language with labels, expressions and comments. The programs can then 
be edited by line number, a powerful feature that makes corrections and additions very 
easy. The program can be named as a file and stored at a user selected memory location 
while another file is being worked on. Files can be listed by line number using the LIST 
command before being assembled. The Assembler converts the Assembly Language 
mnemonic codes and labels to hexidecimal op-codes at any address selected by the user 
to run at any address (the run address may be different from the location in memory 
where the program is placed). Assembly can be performed with or without error 
messages being printed. After assembly the program can be run using the EXECUTE 
command or dumped onto cassette or paper tape using the DUMP command. 


Paper tapes or cassettes of the program listing will not be available to individuals but 
we have already sent paper tapes to several computer clubs around the country. We 
suggest you contact one of the clubs if you want a copy of the tape or need assistance. 
We will be happy to send tape copies to any bona fide "amateur" computer club or 
society, so if you are a member of such a group, please let us know of your group's 
existence by sending us a copy of its latest newsletter. 


In addition we have a manual describing the use of the ALO System from the ground 
up. This will include a complete description with examples of every command, instruc- 
tions on the use of all internal routines by other programs and an overview of efficient 
file generation and handling. 


An even more wonderful version of the ALOS is available in firmware as part of an 
8K PROM module. The expanded version allows dynamic Input/Output allocation, file 
area management by the executive, octal and/or hex data entry, loaders for both 8800 
BASIC and Intel Hex Format tapes, and many other capabilities not included in the 
original Package No. 1. The basic Resident Executive-Editor-Assembler occupies about 
4K of the 8K maximum capacity. So why the 8K?? Because we are leaving space for 
future expansion. The first expansion is a powerful Simulator that adds-on to the basic 
ALOS package. 


SIMULATOR?? Yes, an Interpretive Simulator which runs 8080 programs on the 
same 8080 that contains the Simulator! Not just traps and breakpoints but simulated 
1/0, registers, flags, program counter and stack pointer. Any of these can be modified at 
all times; plus a single step mode that displays all the registers, pointers, flags, etc., after 
execution of each instruction. This Simulator is the most powerful debugging tool for 
the 8080 that we know of. Just think, you will hardly ever again have to touch the front 
panel switches. 


Both versions of our ALOS require 2K bytes of RAM for system internal storage and 
symbol tables. In addition at least 4K more is needed to hold user files, although greater 
capabilities are achieved with 8K or 12K of user space. 


PTCOS ! 


What is PTCOS you may ask?? It stands for Processor Technology Cassette Operating 
System and it means a real Operating System program based around our CDS-VIII dual 
Cassette Data transport System. When operating under this program you have true file 
handling power to create, delete, edit, relocate, and copy all kinds of files (c.g. BASIC 
and programs written in BASIC). PTCOS can handle multiple I/O devices using a special 
type of file and suitable small driving routines. At last an integrated system concept for 
the 8800 is a reality! PTCOS is devilishly similar in its basic operation to an FDOS and is 
upward compatible with future software developments from Processor Technology. 


PRICE LIST effecitve OCT. 1, 1975 
KIT ASSEMBLED DELIVERY 

Software package No. 1 Processor Technology 
Operating System Fourth Street 
Operating System $3.00 - 3 weeks max. 2465 

PTCOS: Processor 94 

Technology Cassette Berkeley, Ca. 710 
Operating System WRITE December °75 

ALS-8 PROM Firm- (415) 549-0857 

ware module expanded 

version of SP No. 1 $275. $325. 3 weeks 

SIM-1 PROM Firm- 
ware add-on to ALS-8: 
Simulator section $95. $110. 3 weeks 


What is a Character ? 


by 
Manfred Peshka 
Peterborough NH 03458 


A character is a unit of 
information used in a com- 
munication between a sender 
and a receiver. Senders and 
receivers may be either 
people or machines, or a mix 
of the two. A character may 
be represented in different 
forms: People use mostly 
graphics, such as the letters of 
the alphabet, the digits or 
occasionally the Roman 
numerals, and the punctua- 
tion and special symbols 
which are so familiar to us. 
Machines process a set of 
electric pulses in a period of 
time which normally repre- 
sents a character. This time 
period differs in length for 
different devices; it is longer 
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for slow devices (terminals, 
card readers, printers) than 
for fast devices (tape and disk 
drives), and is generally the 
shortest for the computer 
arithmetic and logical unit. 
Parenthetically it should 
be noted that some machines 
can recognize graphics, draw- 
ings, and even objects (units 
providing information) in a 
landscape. The discussion of 
these machines, however, is 
reserved to a future article, 
and their cost is far beyond 
that of the amateur and 
hobbyist at the present time. 


Symbolic Representation of 
Alternatives 

What is the minimum 
number of information ele- 
ments, characters, or basic 
symbols needed to express an 
alternative? Probably the 
most common symbol is the 
indicator light which tells us 
that a system is in a specific 
state as opposed to its 
"usual" state. Let's consider 


for a moment the sign "Fire 
Trucks Entering on Blinking 
Red Light" This sign indi- 
cates the possibility of two 
specific states: The "usual" 
state prevails when fire trucks 
are either on a call or waiting 
in the garage; in this situation 
the light is off. The alterna- 
tive consists of an emergency 
when the light is blinking to 
inform people that trucks are 
about to enter the street, or 
just have entered and are 
rushing to the fire. Thereafter 
the light is again turned off. 
The light is pulsing for a 
period of time which nor- 
mally represents this 
particular situation or "unit 
of information," say, about 
20 seconds. 

The indicator light 
actually represents the 
simplest character or basic 
symbol providing a unit of 
information. It is binary 
telling you that a given situa- 
tion either prevails or not. 
Similarly, the door bell, the 


telephone bell, the oil 
pressure light on your car, 
etc. are binary symbols. 
Binary means nothing else 
but a characteristic, property, 
or condition of a system in 
which there are but two alter- 
natives. Besides indicator 
lights, bells, etc, binary 
symbols can take on graphic 
forms such as yes or no, true 
or false, 1 or 0, to name a few 
only. For a machine, the 
form is either the absence or 
presence of a certain elec- 
trical energy level at a period 
of time of specific duration. 
While the duration of 
signaling or "marking" in the 
case of the oil indicator light 
may be variable depending on 
engine rotation, pressure, 
temperature, etc., it is 
constant for computing 
machines. lt may be a 
1/110th or 1/300th of a 
second for a slow terminal, or 
a billionth of a second for a 
computer central processing 
unit. 


Binary and Ternary Symbol 
Sets 


We have seen that one 
binary character suffices to 
indicate two distinct states. 
On the other hand, an 
elevator is in one of three 
states: It is idle, or it is going 
up, or it is going down. 
Naturally one binary symbol 
is not enough to represent 
three states. Two lights may 
be used as follows: The left 
light may signal upward 
motion when illuminated, 
and the right light may signal 
downward motion. No 
upward or downward motion 
is indicated when the 
corresponding light is turned 
off. Let's represent the two 
possible states of the 
indicator lights by the 
graphics 1 of on and O for 
off. The following three 
characters then express the 
three possible states: 


00 [оо ] idle 
01 [ож | down 


Note that a character, that is, 
the unit of information, is 
represented by two bits or 
binary digits. We now have 
used a two-bit character code 
to symbolically represent the 
states of the system 
consisting of the elevator and 
its two lights. 

An entirely different way 
to represent three distinct 
states symbolically is 
accomplished by increasing 
the number of basic symbols 
from two to three. Let's use 
the graphic 2 to indicate 
upward movement. Instead of 
the left and right indicator 
lights, such conditions may 
be indicated by a panel 
displaying the terms idle, 
down, or up as follows: 


0 | IDLE ] neither down 


nor up 
1 [DOWN ] down 
2| UP ] up 


This time we used a code 
consisting of ternary digits to 
symbolically represent the 
three states of the elevator 
and its indicator panel. 
Ternary means that a 
characteristic, property, or 
condition of a system can 
prevail in опе of three 
alternatives. 

Note that the unit of 
information, or in other 
words, the character, has 
been coded in the first case 
by two binary digits, and in 
the second instance by one 
ternary digit. One can 
conceptualize a character as a 
distinguishing mark indicating 
a specific state of a system. 
Characters are "marks of 
distinction" which may be 
represented in different 
graphic forms which have 
equivalent value: 


Binary Ternary Implementation 
00 0 [оо | | IDLE | 
01 1 [ож | [DOWN] 
10 2 [ж J | UP | 


The two bit code permits a 
fourth alternative, namely 11. 
In actuality, this situation 
represents а contradiction 
since the elevator cannot 
move up and down at the 
same time. However, this 
character may be used to 
signal a defect, such as the 
elevator being stuck between 
two floors, or it may simply 
be out of operation. The 
ternary code cannot signal 
this condition unless ап 
additional basic symbol is 
being used; let's assume that 
an additional panel indicates 
a defect when illuminated, 
and the code representing this 
situation consists of a binary 
digit concatenated with a 
ternary digit as follows: 


10 [DEFECT] [IDLE ] 
o0 | | [IDLE |] 
01 | ] [DOWN ] 
02 | |] [ UP |] 


In this situation, the 
character or information unit 
is represented by one binary 
and one ternary digit. It is a 
mixed code, principally 
similar to those found on 
license plates consisting of 
letters and decimal digits. 

In this situation, two of 
the six possible characters 
remain unused, namely 11 
and 12. At least, let's hope 
that they remain unused 
because 11 would mean that 
a defective elevator is in 
downward motion. 


Enumerating Alternatives 


The number of alternatives 
which need to be considered 
in a given system determines 
the coding requirements. The 
more alternatives need to be 
communicated, the more 
"marks of distinction" are 
required. We have seen the 
two basic ways to accomplish 
this: Increase the number of 
distinguishing graphics in the 
character set, or concatenate 
graphics from the same or 
from different sets of basic 
symbols to form strings. 

Obviously there is some 
upper limit to the number of 
distinguishing marks available 
to people. Humans have a 
limit of what they can 
comfortably memorize іп 
terms of numbers of basic 
symbols when there is no 
specific meaning attached to 
them. Consequently there 
comes a point when graphics 
are being concatenated to 
form symbol strings which 
represent words. The string 
3-D stands for the word 
which we pronounce 'thre-'dé 
and which obviously means 
"the three-dimensional form 
or a picture produced in it" 
(Webster's Seventh New 
Collegiate Dictionary 1965: 
page 920). We use the 


decimal digits O, 1, 2, ..., 9 
to represent numbers, the 
letters a, b, c, ..., 2, A, B, 
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., Z to represent the 
alphabet for words; special 
symbols апа punctuation 
marks are concatenated with 
digits and letters to form even 
longer strings to represent 
expressions which inform 
people about one specific 
alternative out of, say, a 
million possibilities. We form 
mathematical expressions 
(x?+x—3, etc.) and word 
expressions (i.e., sentences) 
and a combination of the 
two: "Yesterday it rained in 
Peterborough for two hours." 

The basic unit of 
information is the basic 
graphic symbol or character: 
The space on the paper, the 
special marks (+ — <, ; etc.), 
the letters, and the decimal 
digits, and, which is not 
immediately obvious, certain 
functions like the bell on the 
typewriter which signals the 
approach of the right margin, 
the backspace, the margin 
release, the carrier return, the 
line feed adjustment, etc. The 
latter group is called 
functions or control 
characters. In the computer 
and communications field 
many more functions are 
encountered than there are 
on the typewriter. These will 
be discussed in detail further 
on. 

The number of graphics 
available for marking one out 
of many possible states of a 
system is referred to by the 
name base. Digits are used to 
represent numbers; since 
people generally use ten 
distinct digits, the number 
system is called a decimal 
system. The base of this 
system is 10. In the previous 
section the binary number 
system and the ternary 
system were used. Their bases 
are two and three, 
respectively. 

Using any one of these 
systems, it is possible to mark 
any number of alternatives. If 
the number of alternatives 
exceeds the base (i.e, the 
number of distinct graphics in 
the set) one or more 
additional graphics are used. 


Table 1. Equivalence of Selected Graphics. 


Binary Ternary Octal 
0 0 0 
1 1 1 
10 2 2 
11 10 3 
100 11 4 
101 12 5 
110 20 6 
111 21 7 
1000 22 10 
1001 100 11 
1010 101 12 
1011 102 13 
1100 110 14 
1101 111 15 
1110 112 16 
1111 120 17 
b- 2 3 8 
g= 4 3 2 
a=16 27 64 


As an example, let’s assume 
that we desired to mark any 
one of sixteen alternatives. If 
we used the letters to mark 
these possibilities, as is often 
found in term papers and 
legal documents to mark 
paragraphs and sections, one 
graphic for each alternative 
would suffice. As a matter of 
fact, out of the 52 available 
letters only sixteen would be 
used. Thirty-six graphics 
would not be used. Two 
decimal graphics are required 
to express sixteen options, 
leaving 84 pairs unused. 
Three ternary graphics 
encompass these sixteen 
possibilities leaving eleven 
triplets unused. A quadruplet 
of binary graphics generates 
exactly sixteen possibilities. 

In general, by using ‘g 
graphics of a set with base ‘b’, 
the maximum number of 
alternatives ‘a’ is determined 
by multiplying ‘b’ with itself 
for ‘g’ times, or in other 
words, a=b&. Table 1 
summarizes this rule by 
enumerating all possible 
arrangements of binary, 
ternary, octal (base 8), 
decimal, and  hexadecimal 
(base 16) graphics for the 
first sixteen values ог 
alternatives. 

To illustrate the rule to 
calculate the maximum 
number of alternatives, the 
hexadecimal system requires 


Decimal Hexadecimal 

0 0 

1 1 

2 2 

3 3 

4 4 

5 5 

6 6 

7 7 

8 8 

9 9 
10 A 
11 B 
12 C 
13 D 
14 E 
15 F 
10 16 
2 1 
100 16 


only one graphic (g=1) for a 
maximum of sixteen 
alternatives (a=16) because its 
base equals sixteen (b=16). 
Note, however, that the 
largest value or number 
equals fifteen which is 
represented by the graphic F 
because enumeration began 
with the magnitude zero. 

The maximum value is 
always one less than the 
number ‘a’ because these 
systems start counting with 
zero. Assuming two 
hexadecimal graphics (g=2), 
256 distinct alternatives can 
be identified (а=162). The 
largest value, however, is 
equal to 255 (a—1) because 
the first value is zero. The 
hexadecimal string FF 
identifies the same magnitude 
as the decimal string 255 or 
the bit string 11111111. 

It is easy to change from 
one coding system to 
another, especially from 
binary to hexadecimal and 
back, by means of Table 1. 
The choice of the 
hexadecimal graphics A to F 
was arbitrary and is of great 
help to people. Machines 
represent all characters as 
binary pulses within a given 
time period. Bit strings, 
therefore, can become very 
large and difficult to 
remember. Imagine the bit 
string 10001111011100. 
How much easier it is to 


remember the hexadecimal 
string 23DC instead (you may 
wish to verify the translation 
starting with the right four 
bits). Any other distinct 
graphics instead of A to F 
could have been used; for 
example ! @ # < 96 >, 
However, try to remember 
these in this order, and try to 
pronounce 23<# instead of 
the above 23DC. 


How to Identify Character 
Sets 

Given the possibility of 
switching from one 
representation to another, the 
question of code 
identification must be dealt 
with. Assume the graphic 
representation 3-D. Is it a 
word of the English language? 
Or is it an arithmetic 
expression? If it is an 
arithmetic expression, which 
number system has been 
employed? Assume another 
representation such as 11. 
Which number system has 
been employed and what 
magnitude is represented? 
You may wish to consult 
Table 1 and calculate the 
magnitude for each number 
system. 

In order to avoid 
confusion, graphics other 
than decimal digits, letters, 
and the special symbols are 
identified explicitly. The 
string 11 therefore means 
eleven in the decimal number 
system, and 3-D is part of the 
English language. If a ternary 
string was meant, one needs 
to say so in some 
unambiguous manner. This 
can be accomplished through 
a textual declaration such as 
“AIl following digits аге 
ternary digits’ or, ‘‘The 
ternary number 11 has a 
value of 4” where according 
to our convention the graphic 
4 is understood to be a 
decimal digit. 

A different way to 
identify strings is by 
appending to the string the 
base. In the mathematical and 
computing literature different 
methods have been 


employed. In the 
mathematical literature, this 
is accomplished by a separate 
graphic which is appended to 
the digit string: 112 is a 
binary number with a value 
of three, while 118 is an octal 
number representing nine, 
and 1116 is a hexadecimal 
number representing 17. The 
subscripted graphic represents 
the base, and it is omitted 
whenever the base is ten. This 
convention also avoids the 
confusion about 3-D. This 
string is an expression of the 
English language, whereas 
3-Di6 equals 3-13 or —A16 
which is a numeric expression 
resulting in a number. 

In the computing 
literature, different ways have 
been found to identify bit or 
hexadecimal strings. These 
ways depend on the 
manufacturer and on the 
computing language 
employed. |n American 
National Standard (ANS) 
Fortran, a predominately 
mathematical language 
(which is to be distinguished 
from Basic Fortran), digit 
strings are recognized as 
decimal numbers. Bit strings 
are not allowed, and non-digit 
strings as used for headlines, 
table headings, etc., are 
preceded by one or more 
digits and the capital letter H; 
for example, 4H3.14 means 
the four characters 3.14 
which differ in their internal 
representation from the 
magnitude 3.14. The constant 
4 prior to the H indicates the 
length of the string; it is four 
symbols long. 

In ALGOL 60 which is an 
internationally standardized 
mathematical language, digit 
strings are recognized as 
decimal numbers, and 
character strings for table 
headings, etc., are enclosed in 
so-called string brackets as 
shown in the example: ‘ 
The wife stated that her 
husband told her ‘our 
daughter. complained ‘the 
teacher is giving me trouble’”’. 
Note that it is possible to 
have strings within strings, 
each of which is enclosed by 


the single quotes pair. 

In Programming Language 
One (PL/I), as devised by 
IBM, digit strings are 
recognized as decimal 
numbers unless they are 
appended by the letter B. 
11B equals 112 and has a 
value of 3. Since the internal 
representation of binary 
numbers differs from codes, 
this language also permits 
explicit bit and character 
strings such as '11'B which 
does not necessarily have a 
value of 3 but could mean, 
for example, that the elevator 
is out of order. Alphanumeric 
character strings are also 
permitted and recognized 
whenever they are enclosed in 
single quotes: ‘THIS IS A 
"STRING", ISN'T IT? 
Similar distinctions exist also 
in ALGOL 60 and will be 
discussed in a future article. 

You might have noted that 
the character constants in 
Fortran were preceded by the 
length indicator and an 
identifying character H. In 
the systems using quotes or 
string brackets, the length is 
determined by the number of 
positions occupied between 
the brackets. Many assembler 
languages combine these two 
methods. The string is 
enclosed in quotes, and it is 
preceded by a single letter 
indicating the base. B'11' is 
equal to 11B or ‘11’B and has 
a value of 3 when it is used as 
a number in integer 
arithmetic. X'11' equals 1116 
or 17 and is a hexadecimal 
string. 

The distinction between 
binary numbers and bit 
strings is a rather fine one and 
will be discussed in a future 
article. The computer 
represents all information as 
strings of bits and 
manipulates these strings 
according to their type in 
certain groupings of bits. The 
basic group is called a 
machine word and consists of 
one or more bits. These bit 
groups have an equivalent 
code value which can be 
represented graphically in 
several different ways. 
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Function Abbreviations 


We have discussed earlier 
various functions of the 
typewriter. Computer 
terminals and communica- 
tions equipment use many 
more function characters 
than the common typewriter 
does. In the various codes, 
these functions correspond to 
certain bit strings. The 
functions are indicated in the 
code tables on the following 
pages by abbreviations. 
Therefore, in Table 2 a 
dictionary of these 
abbreviations is presented. 

The more frequently 


encountered terminal 
function codes (as opposed to 
transmission functions) are 
marked with an asterisk. 


The Baudot 
Telegraphy Code 


An operator depressing the 
telegraph key causes current 
to flow through a wire. The 
current actuates an 
electromagnet at the receiving 
end which produces a 
“click”. The timing between 
the clicks represents either a 
dot or a dash, and 
telegraphers yesterday, and 
hams today, are skilled in 


Five-Bit 


Fig. 1. The word BYTE in Baudot Code. 


"MARKING" 1 


"SPACING" о 


н LETS — m— B — 


STOPI 


Table 2. Function Abbreviations. 


+4 1.5 1 
OR 


TIME UNITS 1.42 


ACK Affirmative Acknowledgement 
BEL, BELL Bell or other audible signal 
BS Backspace 

BYP By Pass 

CAN Cancel 

cc Cursor Control 

CR Carriage Return 

Сп 1 Customer Use 1 

CU2 Customer Use 2 

сиз Customer Use 3 

DC Ø Device Control 0. 

DC 1 Device Control 1 

DC 2 Device Control 2 

DC 3 Device Control 3 

DC 4 Device Control 4 (stop) 
DEL Delete 

DLE Data Link Escape 

DS Digit Select 

EM End of Medium 

ENO Enquiry 

EOA End of Address 

EOB End of Block 

EOM End of Message 

EOT End of Transmission 

ERR Error 

ESC Escape 

ETB End of Transmission Block 
ETX End of Text 

FE Format Effector 

FF Form Feed 

FIGS* Figures Shift 

FS Information File Separator 
GS Information Group Separator 
HT Horizontal Tabulation 
IDLE Null 

IFS Interchange File Separator 
IGS Interchange Group Separator 
IL Idle 
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translating these "dots" and 
“dashes” into graphics. 

Transmission speed was 
mostly dependent on the 
telegraphers’ skills. The term 
"baud rate" means the 
frequency at which the dots 
recurred in a second, with 
every dash counting twice as 
long as a dot. 

In the automatic 
teletypewriter the key was 
replaced by а distributor 
which sends a fixed number 
of pulses for each character 
entered on a keyboard. 
Latches at the other end 
actuated a printing device. 


#— Y 


m— T — 


ke- ONE CHARACTER—»} 
= 11 5 


The term “marking” was used 
to indicate the flow of 
current, and the line was 
“spacing” when the current 
was off. Marking and spacing 
can be related to binary 
digits. In Table 3, a mark is 
indicated by the bit 1, and a 
space by the bit 0. In 
addition to the five bits of 
the code, a space occurred 
prior to transmission, and a 
longer mark (1.5 or 1.42 
times the usual mark time) 
terminated the code. Fig. 1 
shows the timing of marks 
and spaces of the string 
BYTE: 


E — 


IRS Interchange Record Separator 
ITB Intermediate Text Block 
IUS Interchange Unit Separator 
LC Lower Case 

LETS Letters Shift 

LF Line Feed 

NAK Negative Acknowledgement 
NL New Line 

NUL Null, or all zeros 

PF Punch Off 

PN Punch On 

PRE Prefix 

RES Restore 

RS Record Separator (Reader Stop) 
RU Are you... ? 

RVI Reverse Interrupt 

50-57 Separator Information 

SI Shift In 

SK Skip (punched card) 

SM Set Mode 

SMM Start of Manual Message 
so Shift Off or Shift Out 

SOH Start of Heading 

SOM Start of Message 

SOS Start of Significance 

SP Space 

STX Start of Text 

SUB Start of Special Sequence 
SYN Synchronous Idle 

TM Tape Mark 

TTD Temporary Text Delay 

UC Upper Case 

US Information Unit Separator 
VT Vertical Tabulation 

VTAB Vertical Tabulation 

WACK Wait Before Transmitting Positive Acknowledgement 
WRU Who are you? 


Prior to transmission of 
the letter B, the code LETS 
must be sent in order to set 
the receiving equipment into 
letter shift mode. The reason 
for this convention is to make 
it possible to transmit more 
than 32 symbols with five 
bits (g=5, b=2, a=32). After 
all, there are already 26 
uppercase letters and ten 
digits; then there is need for 
punctuation and specia! 
symbols, and function 
characters to control the 
printer. Once the operator 
intends to send a numeric 
character, the FIGS code is 
sent prior to the numeric 
string. In addition to the 
numeric characters, several 
other characters were sent in 
figures shift mode. Depending 
on the equipment used, 
various different graphics 
were assigned to the same bit 
strings. Table 3 indicates the 
assignments for four different 
keyboards; the first column 
shows the International 
Telegraph Alphabet No. 2 of 
the Comite Consultatif 
International Telegraphique 
et Telephonique (CCITT); the 
second column shows the 
commercial teletype 
keyboard as used in the 
United States, the third 
column presents the fractions 
keyboard of the American 
Telephone and Telegraph 
Company (ATT); the fourth 
column shows the weather 
bureau keyboard. All four 
different keyboards are 
shown here because used 
equipment from different 
sources may be available to 
you which you might want to 
modify so that all keycaps 
correspond to the commercial 
keyboard. 


Binary Coded Decimal (BCD) 
Transmission Code 

The term “binary coded 
decimal” derives from the 
method of coding decimal 
digits. The bit string with 
value 9 is 1001, and the value 
10 is expressed by adding an 
additional four bits, namely, 
00010000. The bit string 


Table 3. Five-level Baudot Code for Four Selected Keyboards. 


BIT 
CODE 
1 1 
1 0 
о 1 
1 0 
1 
1 
0 1 
0 0 
о 1 
1 1 
1 1 
о 1 
0 0 
0 0 
0 0 
o 1 

1 
о 1 
1 0 
0 0 
1 1 
0 1 
1 1 

1 0 
1 0 
1 0 
0 0 
1 1 
1 1 
0 0 
0 0 
0 1 


о о o 


Upper 
$ 
© 
Lower Е Е 
Case Ө 8 
А —. — 
B ? ? 
C : 
D Mo $ 
E 3 3 
F ! 
G & 
H # 
[ 8 8 
J Bel Bell 
K ( ( 
L ) ) 
M 
N А , 
о 9 9 
Р 0 0 
о 1 1 
R 4 4 
5 , 
T 5 5 
U 7 7 
M = ; 
w 2 2 
X / / 
Y 6 6 
2 + n 
Blank 


Letters shift 
Figures shift 
Space 

Carriage return 


Line feed 


Case 


\ о = 4 [ о N о ө — Weather 


| 


^ 


Table 4. Seven-bit American Standard Code for Information Interchange. 


111 


101 110 


010 011 100 


000 001 


| 


EN хі 
515 |х Sia u | — 
2 ||о|ш «|@|@ 15 |515 |915 


tFor IBM 370, the left ої the two symbols is generally displayed. See Table 2 for explanation of 


function abbreviations. 


Table 5, Six-bit Binary Coded Decimal Transmission Code. 


Bits 3,4,5,6 


< 


pus 


= 


— 


- 
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01011001 therefore has a 
value of 59, and 99 is 
expressed as 10011001. This 
method differs from the bit 
coding shown in Table 1. 

The binary coded decimal 
(BCD) transmission code has 
been widely used by IBM and 
other manufacturers to 
transmit uppercase letters, 
digits, and special symbols in 
a six-bit code. It is a subset of 
the USASCII code; however, 
it is not a national standard. 
The bit strings are shown in 
Table 5. 


The American Standard Code 
for Information Interchange 
(ASCII) 


Throughout the decades, 
many different data 
transmission codes were 
developed, and designers 
today often find good reasons 
to develop their own codes. 
The need for standardized 
transmission codes, however, 
has increased tremendously 
because more and more 
machines dial-up other 
machines via the public 
networks. The American 
Standards Association has 
standardized a seven bit code 
for communications. It 
contains upper and lower-case 
letters, and a large number of 
device and transmission 
control characters. Àn eighth 
bit may be added for parity. 
The term parity implies that 
the number of bits should 
add up to an even number 
(for even parity) or to an odd 
number for odd parity. The 
purpose is to check to some 
degree for a loss of bits 
during transmission. Assume 
that a device transmits in 


even parity; uppercase B 
consists of two marks and 
five spaces, therefore, no 
eighth bit is transmitted; 


uppercase T consists of three 
marks and four spaces, and an 
eighth mark is sent to make 
the number of marks even. 
Fig. 2 shows the string BYTE 
in even parity transmission. 
The code is shown in Table 4. 
Bit 1 is transmitted first. You 
may also want to refer to 
Table 2 in order to 
understand the meaning of 
the abbreviations. 


Extended Binary Coded 
Decimal Interchange Code 
(EBCDIC) 


The Extended Binary 
Coded Decimal Interchange 
Code is essentially the 
previously mentioned Binary 
Coded Decima! code 
extended by two bits to form 
an eight-bit code. A total of 
256 codes are possible (b=2, 
g=8, a=256) and because of 
its length of eight bits, it is 
often more easily expressed 
in hexadecimal notation by 
means of a string of two 
hexadecimal digits. Table 6 
shows both notations, the bit 
pattern and the hexadecimal 
notation. The digit 9, for 
example, is expressed as the 
bit string 11111001, or as the 
hexadecimal string F9. 

The code is often used to 
transmit the eight-bit bytes of 
computers. It originated 
about a decade ago when IBM 
introduced the System 360. 


The terms “EBCDIC”, 
"byte", and “hexadecimal 
digits 0, ..., Е” were 
developed at that time. 


Today these terms are widely 


Fig. 2. The word BYTE in Even-parity USASCII. 
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accepted and used by many 
computer manufacturers. The 
code is also widely accepted; 


however, it is not a national 
standard. 
Conclusions 


A character is a unit of 
information which can be 
represented in various forms, 
Such as in graphic form, or as 
a bit string. Since bit strings 
can be rather lengthy and 
therefore difficult to 
remember, we discussed the 
abbreviated representation of 
the string by means of the 
hexadecimal graphics. The 
relationship between the bit 


string representations of 
characters and the 
hexadecimal graphics is 


independent of the code since 
it is based on an intrinsic 
numerical order, namely that 
of counting from zero by one 
to infinity. 

On the other hand, bit 
strings may be represented by 
graphics in an entirely 
different manner depending 
on the code used. For that 
purpose we looked at the 
predominant five-, six-, seven- 
and eight-bit codes presently 
in use. We did not discuss 
various other but less 
important codes because of 
space limitations. Depending 
on the code utilized, the same 
graphic represents entirely 
different bit strings as shown 
in Table 7. 

The first character in the 
Baudot code is the letters 
shift. Note the similarity 
between the last three codes 
which holds only for 
uppercase letters and digits. 


а c t a tr 
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Table 6. Eight-bit Extended Binary Coded Decimal Interchange Code. 


00 01 10 11 00 01 10 11 00 01 10 11 00 01 10 11 


A J 
2 STX DC2 FS SYN b k s B K S 2 
3 ETX TM c | ї C L T 3 
4 PF RES BYP PN d m u D M U 4 
5 HT NL LF RS e n v E N V 5 
6 LC BS ETB UC f о w F о Ww 6 
7 DEL IL ESC EOT g p x G P X 7 
8 CAN h q y H Q Y 8 
9 EM i r z l R Z 9 
A г -——-- 9 
B Special Graphic Characters 
c d Cent Sign - Minus Sign, Нурһеп | 
D Period, Decimal Point / Slash 
E < Less-than Sign , Comma | 
F ( Left Parenthesis 96 Percent | 
To conclude this tutorial, * Plus Sign -= Underscore, Break | 
let me say this in EBCDIC | Logical OR Character 
(without start, stop and & Ampersand > Greater-than Sign | 
parity bits): | ! Exclamation Point ? Question Mark | 
D5 85 АТ АЗ 6B $ Dollar Sign : Coton 
40 A6 85 7D 93 | | | | 
93 40 84 89 A2 | * Asterisk # Number Sign | 
83 А4 A2 A2 40 ) Right Parenthesis е At Sign 
95 A4 94 82 85 | ; Semicolon ' Prime, Apostrophe | 
99 A2 4B | ү Logical NOT = Equal Sign | 


Quotation Mark 


Table 7. Transmission of the String BYTE in selected codes (excluding 
start, stop) and parity bits). 


11111 10011 10101 00001 10000 Baudot 
000010 101000 100011 000101 BCD Transmission Code 
0100001 1001101 0010101 1010001 USASCII (see Note 1) 


11000010 11101000 11100011 11000101 EBCDIC 


Note 1. In memory, the sequence of bits on the IBM 360 and 370 is 
reversed. The left bit shown becomes the right bit, etc., as shown: 


1000010 1011001 1010100 1000101 


featuring MITS Altair Computers 


FULL SERVICE COMPUTER STORE 


Byte'Tronics is the hobbyist’s dream come true. A full service computer store featuring 
the full line of Altair Computer products backed by the most complete technical service 
available. 


The prices at Byte’Tronics are MITS factory prices and most items are available on 
an off-the-shelf basis. 

ByleTronics sponsors the local Altair Users Group of East Tennessee and Byte'Tronics is 
interested in communicating with computer hobbyists throughout the world. 


If you have a question about Altair hardware (whether or not you are a Byte'Tronics 
customer), we will put you directly in touch with our Technical Director, Hugh Huddelston. Hugh 
is an expert troubleshooter who has a thorough knowledge of each portion of each Altair 
board. And he can answer all your questions about custom interfacing. 


If you have questions about software or if you want some custom programming, our 
Software Director, Jonnny Reed, is the expert who can take core of your needs. Johnny has 
had years of programming experience, and he is familiar with Altair BASIC, assembler and 
machine language programming. 

If you have questions about the availability of a MITS product or its price or specifications, 
we will let you talk to Bruce Seals, our Director of Marketing. 


At Byte Tronics we want you to understand your Altair and we are willing їо give you all 
the technical support you need. 


Byte’Tronics sells computers. Byte'Tronics sells service. 


For more information, visit our store in Knoxville—or write or call us. We want to hear 
from you. 


BYTE TRONES 


5604 Kingston Pike, Knoxville, Tennessee 37919 Phone 615-588-8971 
Office hours: 40 a.m. to 40 p.m. Monday-Friday and 9 a.m. to 10 p.m. Saturday. 


MITS-MAS 


Christmas Catalog 


Lowest Price in the World! 


In January of 1975, MITS stunned the computer world with 
the announcement of the Altair 8800 Computer that sells for 
$439 in kit form. 

Today MITS is announcing the Altair 680. 

The Altair 680, built around the revolutionary new 6800 
microprocessor chip, is the lowest priced complete computer on 
the market. Until December 31, 1975, this computer will be sold 
in kit form for the amazing introductory price of $293! (A 
savings of $52!) 

The Altair 680 comes with power 
supply, front panel control board, 
and CPU board inclosed in an 
11" wide x 11" deep x 4 11/16" case. 
In addition to the 6800 processor, 
the CPU board contains the following: 

1. 1024 words of memory (RAM 
2102 type 1024 x 1-bit chips). 

2. Built-in Interface that can 
be configured for 
RS232 or 20 mA 
Teletype loop 
or 60 mA 
Teletype. 

3. Provisions for 
1024 words of 
ROM or PROM. 


The Altair 680 can be 
programmed from the front 
panel switches or it can be 
connected to a computer terminal (RS232) or a Teletype such as 
an ASR-33 or surplus five-level Baudott Teletype (under $100). 
The Altair 680 can be utilized for many home, commercial or 
industrial applications or it can be used as a development system 
for Altair 680 CPU boards. With a cycle time of 4 microseconds, 
16-bit addressing, and the capability of directly addressing 
65,000 words of memory and a virtually unlimited number of 
I/O devices, the Altair 68015 a very versatile computer! 


Altair 680 Software 


Software for the Altair 680includes a monitor on PROM, 
assembler, debug, and editor. This software is available to Altair 
680 owners at a nominal cost. 

Future software development will be influenced by customer 
demand and may include BASIC on ROM. MITS will sponsor 
lucrative software contests to encourage the rapid growth of the 
Altair 680 software library. Programs in this library will be made 
available to all Altair 680 owners at the cost of printing and 
mailing. 

Contact factory for updated information and prices. 


Altair Users Group 


All Altair 680 purchasers will receive a free one year 
membership to the Altair Users Group. This group is the largest 
of its kind in the world and includes thousands of Altair 8800 and 
680 users. 

Members of the Altair Users Group are kept abreast of Altair 
developments through the monthly publication, Computer 
Notes. 


e MITS 


Altair 680 Documentation 


The Altair 680 kit comes with complete documentation 
including assembly manual, assembly hints manual, operation 
manual, and theory manual. Assembled units come with 
operation and theory manuals. Tumkey model and CPU boards 
also include documentation. 


NOTE: Altair 680 manuals can be purchased separately. 
See back page of this catalog for prices. 


Delivery 


Personal checks take 2-3 weeks to 


process while money 
orders and credit card 
purchases can be 
processed in 1-3 days. 
Delivery should be 
30-60 days but this 
can vary according to 
order backlog. All 
orders are handled 
on a first come, first 
served basis. 


Altair 680 Prices 


Altair 680 complete computer kit .... $293 
($345 after December 31, 1975) 


Altair 680 assembled and tested ........................ $420 
Altair 680T turnkey model (complete Altair 680 except 
front panel control board) Kit Only ................. $240 


($280 after December 31, 1975) 


Altair 680 CPU board (including pc board, 6800 micro- 
processor chip, 1024 word memory, 3 way interface 
and all remaining components except 


power supply) ............................................уу[ү $180 
($195 after December 31, 1975) 
Altair 680 CPU board assembled and tested ........ $275 
Option I/O socket kit (required when interfacing 
680 to external devices) ................................. $ 29 
Option cooling fan (required when expanding 
680 internally) .............................................. $ 16 
($22 after December 31, 1975) 
Option cooling fan installed .............................. $ 26 
PROM kit (256 x 8-bit ultraviolet, erasable 
1702 devices) .................................. HH $ 42 


TS 


“Creative Electronics” 


Prices. delivery and specifications subject to change. 


“PROJECT BREAKTHROUGH! 
World’s First Minicomputer Kit 
To Rival Commercial Models... 


‘Altair 8800’ ” 


The Altair 8800 from MITS is now one of the most 
successful computers ever delivered. Thousands of Altair 
8800's have been sold and are in the field where they are 
being used for an infinite variety of industrial, business, 
science and home applications. 


The Altair 8800 is extensively supported 
by ongoing hardware and 
software development. 
Altair 8800 interface and 
memory modules and 
Altair peripherals are 
inexpensively priced, yet 
among the highest quality 
in the business. Byte for 
byte, Altair 8800 BASIC 
language software is the 
most powerful BASIC 
ever written. 


Thanks to the success of the 
Altair 8800, building and 
programming computers has 
become one of the World's most exciting 
and fastest growing hobbies. Local Altair 8800 

Users Clubs have been formed across the United 

States and in such far away places as England and Japan. 


Thanks to clean, efficient design and accurate, easy to 
understand assembly instructions, the Altair 880015 an 
easy kit to assemble. As an Altair 8800 kit builder, you will 
have the satisfaction of successfully building your own 
computer and you will learn about the internal structure of 
digital computers. 


As the owner of an Altair 8800, you will be backed by the 
technical expertise of the MITS Customer Service 
Department. You will receive the latest update 
information, programming hints, technical advice and 
general computer information on a monthly basis through 
a free subscription to Computer Notes. You will be in 
contact with other Altair $800 owners through the Altair 
Users Group and you will have access to the extensive 
Altair 8800 Software Library. 


No other computer on today's market can offer you 
as much support as the Altair 8800. 


Christmas Special 


For a limited time only, you can be the owner of an Altair 
8800 with a 1,024 word memory module for just $68 a 
month! See back page of this catalog for all the details. 


headline on cover of Popular Electronics, 
January, 1975 


Altair 8800 Features 
Built around the most successful (and many say the most 


powerful) microprocessor 
chip ever [the Intel 8080], the 
Altair 8800 is a variable word 
length computer with an 8-bit 
processor, 16-bit addressing 
and a maximum word size 


К.с RPE of 24-bits. It has 78 basic 
Capi ninnu e zy 519. 713 | 


machine instructions with 
variances over 200 instructions. 
The Altair 8800 can directly 
address 256 input and 256 
output devices and up to 
65,000 words of memory. 


Up to 300 peripherals can be 
interfaced to the Altair 8800 
without any additional buffering. 
The custom designer can interface 

almost any number of imaginable devices 
simultaneously. АП Altair peripherals are 
supplied with software handlers to make 
interfacing easy. 


The Altair 8800 includes the CPU board, front 

panel contro! board, power supply (enough to power any 
additional cards), and expander board (with room for 3 
extra interface or memory modules) all inclosed in a 
handsome, aluminum case complete with sub-panel and 
dress panel. Up to 16 cards can be added inside the main 
case. 


Altair 8800 Prices 


Altair 8800 Computer kit (includes 
assembly hints, assembly, operator's, 


and theory manuals) ......................... $439 
Altair 8800 assembled ......................... $621 
Expander board (adds 4 slots) ........... $ 16kit 
со Oea assembled, $ 31 
Cooling fan ..................................... $ 16kit 


Altair Modules – 


Custom Design Your Computer System to Meet Your 
Application (and stay within your budget!) 


1. Three 8800 memory modules. Three 
memory modules are now available for the 
Altair 8800 and more are in the works. These 
modules include a 1K (1,024) word static card, 
a 2K (2,048) word static card, and a 4K (4,096) 
word dynamic card. Each of these modules is 
constructed with the finest components 
available and each contains memory protect 
features (prevents the computer from accidently 
writing over programs you want to save). The 
maximum access time of the static cards is 850 
nanoseconds while access time for the dynamic 
card is 300 nanoseconds. 


2. Four 8800 Interface Modules. Interface 
modules now available for the Altair 8800 in- 
clude three serial and one parallell 1/O cards. 
The SIOA serial card is used to connect the 
Altair 8800 to CRT's and other computer ter- 
minals that have industry standard RS232 
asynchronous interconnect lines. It has divider 
logic to allow for presettable baud rates up to 
19,200 baud (5-8 data bits). 


The SIOB is the same as the SIOA except that 
all signals are TTL levels. This card is a general 
purpose serial interface that can be used to 
custom interface the Altair 8800 to a wide varie- 
ty of devices. 


The SIOC is also the same as the other serial 
cards except it is used to interface the Altair 
8800 to conventional Teletypes and other asyn- 
chronous 20 mA current loop terminals. The 
SIOC is required to interface the Altair with 
ASR-33 Teletypes available from MITS. 

The PIO parallel interface card is used for 
bidirectional transmission of bytes at speeds up 
to 25,000 bytes/second! It is a full TTL compati- 
ble input/output card with necessary hand- 


shake flags for conventional! parallel interface. 
Both input and output data have their own 8-bit 
latch for buffering. Includes necessary logic to 
allow an adjacent channel to be a control 
channel. Most commonly used to interface the 
Altair 8800 to SWTPC-TVT's or equivalent, 
custom A/D-D/A interfacing, computer to com- 
puter interfacing, and control applications. 


3. Audio-Cassette Interface. This best- 
selling Altair module allows you to connect your 
Altair 8800 to any tape recorder (medium quali- 
ty cassette is adequate) for inexpensive mass 
storage. lt works by modulating (changing) 
digital signals from the computer to audio 
signals for recording data and by demodulating 
the audio signal for playback. Consists of a 
special Altair modem board “piggy-backed” on 
an SIOB board. Requires one slot in the 8800. 


4.8800 PROM module. This PROM 
memory card is designed to hold up to 2K of 
PROM. Contact factory for price and other in- 
formation. Altair 8800 PROM Programmer to 
be announced soon. 


5. 680 CPU board. The Altair 680 CPU board 
is a complete computer on a board (less power 
supply). In addition to the 6800 CPU available 
from Motorola and AMI, the Altair 680 CPU 
board comes with 1K of RAM memory (2102 
type, 1024 x 1-bit chips), built-in I/O that can be 
configured for RS232 or 20 mA current loop or 
60 mA current loop, and provisions for 1K of 
ROM or PROM. It measures 8%” x 10%”. 


6. 8800 CPU board. The heart of the Altair 
880015 its CPU board. This double-sided board 
was designed around the powerful byte 


oriented, variable word length 8080 pro- 
cessor—a complete central processing unit on a 
single LSI chip ‘using n-channel, silicon gate 
MOS technology. The CPU board also contains 
the Altair system clock—a standard TTL os- 
cillator with a 2.000 MHz crystal as the feedback 
element. 


Altair Module Prices: 
1K static memory ..................... $97 kit 
and $139 assembled 
2K static memory ................... $145 kit 
and $195 assembled 
4K dynamic memory ............... $195 kit 
and $275 assembled 
SIOA interface ................... wee $119 kit 
and $138 assembled 
SIOB and SIOC interface ......... $124 kit 
and $146 assembled 
РІО interface ........................... $92 kit 
and $114 assembled 
Audio-cassette interface ......... $128 kit 
and $174 assembled 
680 CPU board kit .................. $180 kit 
[$195 after December 31, 1975] 
680 CPU board, assembled ........... $275 
8800 CPU board ..................... $310 kit 
and $360 assembled 


NOTE: Watch our advertisements 
for announcement of new Altair 


. 8800 modules and Altair 680 


modules. 


BASIC language was chosen for the Altair 8800 because it is the easiest 
language to learn and because it can be used for an infinite number of 
applications. Literally hundreds of thousands of BASIC programs have 
been written and are in the public domain. These programs include ac- 
counting programs, business programs, scientific programs, educational 
programs, game programs, engineering programs, and much more. 


Altair BASIC is an interactive language. This means that you get im- 
mediate answers and you can use your Altair as a super programmable 
calculator as well as for writing complicated programs. 


8K BASIC Features 


Altair 8K BASIC leaves approximately 2K bytes in an 8K Altair for 
programming which can also be increased by deleting the math functions. 
This BASIC is the same as the 4K BASIC only with 4 additional 
statements (ON GOTO, ON .. GOSUB, OUT, DEF]. 1 ad- 
ditional command [CONT] and 8 additional functions [COS, LOG, 
EXP, TAN, АТМ, INP, FRE, POS]. Other additional features include multi- 
dimensioned arrays for both strings and numbers, AND. OR, NOT 


bb е seen and used other BASICs, but byte-for-byte, Altair 
is the most powerful BASIC I've seen. I'm particularly im- 
pressed with the n-dimensional arrays (and for strings 
tool), machine level I/O, and machine language ‘function’ 
features. The level of your documentation is, for me, 
though the high point. Sections for those who know 
nothing and sections for those who know a lot, plus sec- 
tions that ‘normal’ people can read and understand. ™ 


J. Scott Williams 
Bellingham, Washington 


Altair BASIC was written as efficiently as possible to allow for the max- 
imum number of features in the minimum amount of memory. You can 
order one of three Altair BASICs: 4K BASIC-designed to run in an Altair 
8800 with as little as 4K of memory, 8K BASIC, or EXTENDED BASIC 
(12K). Each of these BASICs allows you to have multiple statements per 
line (a memory saving feature), and each of them is capable of executing 
700 floating point additions per second! 


The 8K BASIC and EXTENDED BASIC have multi-dimensioned 
arrays for both strings and numbers. This is particularly useful for 
applications requiring lists of names or numbers such as accounting 
programs, inventory programs, mailing lists, etc. 


The 8K BASIC and EXTENDED BASIC also have an OUT and cor- 
responding INP statement that allows you to use your Altair 8800 control 
low speed devices such as drill presses, lathes, stepping motors, model 
trains, model airplanes, alarms, heating systems, home entertainment 
Systems, etc. 


Altair BASIC comes with complete documentation including a copy of 
"My Computer Likes Me When I Speak in BASIC" by Bob Albrecht, a 
beginner's BASIC text. 


Never before has such a powerful BASIC language been 
marketed at such low prices! 


4K BASIC Features 


Altair 4K BASIC leaves apporimxately 750 bytes in a 4K Altair for 
programming which can be increased by deleting the math functions. This 
powerful BASIC has 16 statements [IF . THEN, СОТО, GOSUB, 
RETURN, FOR, NEXT, READ, INPUT, END, DATA, LET, DIM, REM, 
RESTOR, PRINT, and STOP] in addition to 4 commands [LIST, RUN, 
CLEAR, SCRATCH] and 6 functions [RND, SQR, SIN, ABS, INT and 
SGN]. Other features include: direct execution of any statement except 
INPUT; an't " symbol that deletes а whole line and a " «- " that deletes 
the last character; two-character error code and line number printed when 
error occurs; Control C which is used to interrupt a program: maximum 
line number of 65, 535; апа all results calculated to at least six 
decimal digits of precision. 


operators that can be used in IF statements or forumlas, strings with a 
maximum length of 255 characters, string concatenation (A$ = B$) and 
the following string functions: LEN, ASC, CHAR$, RIGHT$, LEFT$. 
MID$. STR$, and VAL. 


EXTENDED BASIC 


Altair EXTENDED BASIC is the same as 8K BASIC with the addition 
of double precision arithmetic, PRINT USING and disk file 1/0. A 
minimum of 12K memory is required to support EXTENDED BASIC. 

Other Altair 8800 software includes a Disk Operating System. 
assembler, text editor, and system monitor. Altair users also have access to 
the Altair Library. which contains a large number of useful programs. 


SOFTWARE PRICES: 

Altair 4K BASIC ................... дс. $150 

Purchasers of an Altair 8800, 4K of Altair memory, 

and an Altair I/O board ........................................ $ 60 
Altair 8K BASIC ............sssesssesssse eme $200 

Purchasers of an Altair 8800, 8K of Altair memory, 

and an Altair I/O board _........................................ $ 75 
Altair Extended BASIC .................................. $350 

Purchasers of an Altair 8800, 12K of Altair memory, 

and an Altair I/O Board _...................................... $150 
Altair PACKAGE ONE (assembler, text editor, 

system monitor) ...........sssssssee $175 

Purchasers of an Altair 8800, 8K of Altair memory, 

and an Altair I/O board ............................. .......... $ 30 
Altair Disk Operating System ............... sse $500 

Purchasers of an Altair 8800, 12K of Altair memory, 

Altair I/O and Altair Floppy Disk .......................... $150 


Note: When ordering software, specify paper tape or 
cassette tape. 


Inexpensive, Sophisticated Mass 
Storage 


The Altair Disk can store over 300,000 words of information 
on a floppy disk! It offers the advantage of nonvolatile memory 
(doesn't “forget” when power is turned off) and fast access to 
data (34 seconds—worst case). The data transfer rate of the Altair 
Disk to and from the computer is a whopping 250,000 bits per 
second. 


The Altair Disk includes the disk controller, disk drive, one 
floppy disk and a software driver. The disk controller, which con- 
sists of two cards requiring two slots in the 8800, is capable of 
controlling up to 16 disk drives. It controls all mechanical func- 
tions of the disk. presents the disk status to the computer, and 


converts serial data to 8-bit parallel words and vice versa for rapid 
transfer. 

The disk drive consists of a Pertec FD400 drive mounted in an 
Altair case including power supply, a buff/multiplexer board, and 
cooling fan. Its rotational speed is 360 rpm, track to track access 
time is 10 msec., average time to read or write is 400 msec., and 
disk life is over 1 million passes per track. 

The floppy disk is hard sectored for 32 sectors per track (128 
words per sector). There are 77 tracks on each disk. Extra floppy 
disks are available for $15 from MITS. 

A Disk Operating System (software) with complete file struc- 
ture and utilities for copying, deleting and sorting files is also 
available. 


PRICES: 


88-DCDD Altair Disk (includes 
disk controller, disk drive, one floppy disk 


and software driver) .............................. $1,480 kit 
— га ваз assembled, $1,980 
88-DISK Altair Disk Drive only .................. $1,180 kit 
NV NE assembled, $1,600 
Floppy disk .................ssseeeenmHe $ 15 
Disk Operating System 
(if purchased separately) ....................... $ 500 


Purchasers of an Altair 8800, 12K of 
Altair memory, Altair I/O and 
Altair Disk (88-DCDD) .......................... $ 150 


Build Your Own Advanced 


Terminal! 


The Comter Il is easily the most advanced computer terminal 
kit on the market. [t has its own internal memory of 256 
characters which combines with a highly-readable, soft orange 32 
character display to provide ease of operation and information 
retrieval. 


Complete cursor control allows you to move data in and out 
of the display and operate the Comter II with the versatility of a 
CRT terminal. Built-in audio-cassette interface allows you 
to store unlimited data from the computer and feed that 
information back into the computer. 

Other features include auto transmit which allows line-by-line 
transmission of data or program information to the computer 
from the Comter's memory The Comter II has a complete ASCII 
encoded keyboard with TTY-33 format plus the addition of 
special function keys. Its total weight is just 15 lbs. 

Flexible power requirements allow you to operate the com- 
puter at either 95-125V or 190-250V. The Comter II can be inter- 
faced to any computer with an RS232 serial interface. Requires 
an SIOA board to be connected to the Altair 8800. No interface 
required to connect to the Altair 680. 


PRICES: 
Comter П kit with built-in 

audio cassette I/O ........................................ $780 
Comter IL assembled ........................................ $920 


High Speed Printing at Low Cost! 


The Altair 110 Line Printer is a desktop line printer that 
produces 80 columns of 5 x 7 dot matrix characters at 100 
characters per second x 70 lines per minute. The impact head 
prints bidirectionally on a 8%” roll paper" using a conventional 
teletype ribbon. The Altair Line Printerwill print up to four copies 
of any item. 


Maximum reliability is provided by a mechanism which con- 
tains no brakes, clutches, dampers or stepper motors. All control 
electronics including one-line buffer and self-test circuitry are 
contained on a single 5" x 15" printed circuit card. The Model 
110 was expressly designed for the simplicity, reliability and ex- 
tremely low cost required by current small-scale data handling 
systems and terminals. 

Vibration and wear are minimized because the print head 
moves uniformly in both directions and pauses only at the end of 
each line. Opto-electronic sensing is used to accurately position 
each dot and permit characters to be printed on the fly. 

The Altair 110 Line Printer comes with complete control elec- 
tronics including a printer control card. Requires one slot in the 
Altair 8800. 


*Pin-fed Optional. 


Very Low Cost 
Terminal 


PRICES: 


Altair Line Printer with 
controller card ...................................... $1,750 kit 
TP ERI assembled, $1,975 


Teletype — 
Most Versatile 


The Altair VLCTis ideal for machine language programming. 
It converts a three digit octal code directly into an 8 digit binary 
code for transmission to the computer and then displays the 
binary output from the computer in a 3 digital octal format. This 
allows you to program in octal which is much easier than 
programming in binary In addition, the VLCT is much more con- 


venient to work with than using the front panel switches of the 
Altair 8800. . 


PRICES: 


МЕСИ rU $129 kit 
sth, Meads ident tata Sate dee „ыш assembled, $169 


NOTE: PIO interface module is required to connect 
VLCT to Altair 8800. 


With a built-in paper tape reader and punch and hard copy 
output, this ASR-33 Teletype is perhaps the most versatile of all 
low cost input/output devices. 

The ASR-33 Teletype prints 10 characters per second. It is a 
completely checked-out machine with standard 120 day warran- 


ty 


PRICE: 
ASR-33 Teletype ............................................ $1,500 


NOTE: SIOC interface module is required to connect 
Teletype to Altair 8800. 


Christmas Time Payment Plan 


1K Altair for Just $68 a Month! 


You can be the owner of an Altair 8800 with a 1.024 
word memory module for just $68 a month. Each month 
(for 8 months) you send in your payment and we send 
you part of an Altair kit until you have the complete 
system. The advantages of the plan are NO interest or 
financing charge, GUARANTEED price based on today's 
price. and free, immediate membership to the Altair Users 
Group including subscription to Computer Notes. 


Our terms are cash with order, BankAmericard, or Master 
Charge. If you send in an early payment, we will make 
an early shipment. By the same token, a late payment 
will result in a late shipment. (After 60 days past due, 
the balance of the deal is cancelled. All payments must 
be made within 10 months). 

Total $544.00 (Retail price: Altair 8800 $439.00, Memory 


$97.00, Postage and Handling $8.00 — 
total $544.00) 


Altair Users Group Special 


Each month the Altair Users Group sponsors a software contest and 
each month MITS gives away $130 in credit to the winners of this 
contest, At the end of the year. the author of the overall best program 
will receive $1000 in credit. 

Membership to the Altair Users Group (the largest of its kind in the 
world) is free to Altair 8800 owners. However, even if you don't own an 
Altair. you can be an associate member for one year at the special low 
price of $10 (regularly $30). 

As a member of the Altair Users Group. you will be kept informed of 
Altair developments. software contests. and general computer news 
through the monthly publication. Computer Notes. You will have access 
to the Altair Software Library and you can communicate to other Altair 
users throughout the world. 

Note: These specials expire on January 30, 1976. 


Altair Manuals 


Altair 8800 Орегаїогв................................ $ 7.50 
Altair 8800 АзветЬу................................ $ 9.00 
Altair 8800 Theory, Ѕсһетайсѕ........................ $10.00 
Altair 680 Орегаїог$................................. $ 7.50 
Altair 680 АвветЬу.....‚........................... $ 7.50 
Altair 680 Theory, Ѕсһетаісѕ......................... $10.00 
BASIC Language Ооситегпїайоп....`................... $10.00 
Assembler, Monitor, Е@йог............................ $ 7.50 
8800 4K Memory (includes Assembly, Theory & Schematics). $ 5.00 
8800 2K Метогу.................................... $ 5.00 
8800 1K Метогу.................................... $ 5.00 
SBÜOSION. cocto et иж» кыта ш шады ke $ 5.00 
S800'SIOBE ... die: sue dey cate i VA a am к э ке eros EUER $ 5.00 
Ci URIO C" $ 5.00 
ВВООРІО 1: vis yere eere Rye ee Bag ea e REN dre $ 5.00 
8800 ACRA uiae e ларо Mowe ba ner $ 5.00 
COMTER II Орегаїоїз............................... $ 6.50 
COMTER II АзветЬу.......‚........................ $10.00 
COMTER II Theory, Schematics.........: Т ae $10.00 
VLCT (Assembly, Operators, Тһеогу).................... $ 5.00 
Altair Line Printer Їїпїегїасе............................ $ 5.00 


Documentation Special One 


Altair 8800 Operators. Assembly and Theory manuals plus BASIC 
Language manual (regularly $36.50). Now just $15.00. 


Documentation Special Two 


Altair 680 Operators. Assembly and Theory manuals. Regularly $25. 
Now just $14.50. 


Documentation Special Three 


BASIC Language manual. Package ! (Assembler. Monitor, Editor). and 
BASIC language beginners text (My Computer Likes Me When I Speak 
BASIC by Bob Albrecht). Regularly $19.50. Now just $12.50. 


MITS/6328 Linn NE/Albuquerque, NM 87108 
505-265-7553 or 262-1951 


Mail this special Altair Coupon Today! 


O Enclosed is check for $- - 
(7 Altair 8800 O Kit O Assembled LJ Fan 


O BankAmericard # 


O Christmas Time Plan 
П Altair 680 CJ Kit 0 Assembled O Fan O I/O Sockets 


. 0 or Master Charge # 
[1 Expander Board 


О Teletype C Line Printer O Comter II LT VLCT C Disk L] Disk Drive Only LJ Disk Controller Only 


О Memory Module O Vo Module ‘list on separate sheet) 


Postage & Handling: Add $8 for Altair 8800 or Altair 
680 and $3 for any cards or peripherals if ordered 
separately. Teletype and Line Printer shipped by collect 


О Documentation Special One 
О Altair Users Group plus Computer Notes 
О Please put me on your mailing list 
BILLTO: ` 


NAME . eS 


ADDRESS: 
CITY 
STATE & ZIP. 

COMPANY (IF APPLICABLE) 


MITS/6328 Linn NE/Albuquerque, NM 87108 


freight. Warranty: 90 days on parts for kits and 90 
days on parts and labor for assembled units. Prices, 
specifications, and delivery subject to change. 


О Documentation Special Two L. Documentation Special Three 


SHIP TO: à 


STATE & ZIP 


О Please send Christmas Card to above address 
announcing gift and anticipated delivery. 


505-265-7553 or 262-1951 


LIFE Line 3 


by 
Car] Helmers 
Editor, BYTE 


Program design is a process which can be approached in a 
haphazard manner — or by a systematic exploration of what is 
needed to achieve the desired end. LIFE Line 2 in BYTE #2 
began the systematic exploration of the Tree of LIFE by 
presenting information on the overall program design of LIFE, 
as well as the details of the GENERATION algorithm used to 
carry one generation of LIFE into the next. 

LIFE Line 3 continues the development of LIFE by a 
discussion of the KEYBOARD INTERPRETER procedure. 
This procedure monitors the "user inputs" of a keyboard, and 
uses the command keystrokes detected to dictate what LIFE 
will do. As in the exploration of the GENERATION 
algorithm, the presentation starts at the top and works 
downward, 


Fig. 1. Data concepts for LIFE program and graphics control. The 
variables XCOL, YROW, N and ENTRY are 8-bit "software registers" 
maintained as variables in the LIFE program. 


INCREMENT/DECREMENT Y 


INPUTS FROM MOVECURS 
ROUTINE 


DEFAULT N= О AT START == 


OF KEYBOARD INTERPRETER 


DEFAULT ROUTINE ASCII NUMERIC 


DATA DEFINES ENTRY 
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"Y" COMMAND 


DISPLAY SCREEN IMAGE 


/ 
4 


^ 
/ LIFEBITS ARRAY КА 


Y CURSOR 
POSITION 


X CURSOR 


GENERATION COUNT POSITION 


ROUTINE 


SPECIAL LIFE CONTROL 
PANEL AND ASCII 
KEYBOARD 


INCREMENT/DECREMENT X 
INPUTS FROM MOVECURS 


Much of the challenge and 
fun of the LIFE application is 
the fact that it is best 
implemented with some form 
of interactive graphics. In the 
partition of the application 
presented in LIFE Line 2, 
one of the major pieces of the 
program is the KEYBOARD 
_INTERPRETER with its 
interactive graphics concepts. 
A good place to start the 
discussion of the 
KEYBOARD. INTER 
PRETER is the software 
block diagram of the 
interactive graphics system of 
LIFE. 


A Software Block Diagram? 


Yes! Strange as it may 
sound to hardware types, the 
ebb and flow of data in a 
program can be depicted in 
block diagrams. While Fig. 1 
looks very much like an 
ordinary hardware block 
diagram of some system, it is 
descriptive of the p/an of data 
flow in a program rather than 
actual wires. Fig. 1 is the 
programming equivalent in 
every respect of the hardware 
block diagram of some 
dedicated interactive graphics 
system. By retaining the 
system in software, LIFE is 
inherently more flexible than 
any hard-wired system could 
be. This block diagram 
illustrates the potential flow 
of data in LIFE as controlled 
through the KEYBOARD _ 
INTERPRETER and its 


subroutines. Data flows and 
changes in response to the 
several input commands 
defined for the program. 

As was pointed out in 
LIFE Line 1, the 
fundamental tool of an 
interactive graphics 
application is a cursor which 
illustrates where the program 
thinks attention should be 
placed. This cursor is flashed 
on and off on the screen, and 
can be moved through 
appropriate commands of the 
user sent via a keyboard. The 
cursor concept is 
implemented in the LIFE 
program application by 
means of two “global” 
variables called XCOL and 
YROW. These are both 8-bit 
bytes of data. But since the 
maximum dimension value in 
either the X or Y directions 
of the display is 63 (i.e., 6 
bits) only the low order 6 bits 
have significance for cursor 
control. At any point in time 
during the execution of 
LIFE, the variables YROW 
and XCOL retain the location 
of the cursor for 
KEYBOARD. INTER- 
PRETER's use. 

Fig. 1 also shows arrows 
directed from XCOL and 
YROW to intersecting dotted 
lines in the LIFEBITS array. 
These two numbers together 
have 12 bits of significance. 
This is sufficient to uniquely 
specify one of the 4096 bits 
in the array using the utility 


subroutines LGET and LPUT 
to reference and change 
LIFEBITS, respectively. 
These routines are left to a 
later LIFE Line for their 
details. 

A ''ghost copy" of 
LIFEBITS is also shown in 
back of the main copy in the 
drawing to emphasize the 
following point: Each bit of 
the internal LIFEBITS array 
maps directly into a 
corresponding bit in the 
refresh memory of the CRT 
display subsystem. This is an 
example of a common theme 
throughout the use and abuse 
of computer systems: 
Software systems map into 
corresponding hardware — 
and vice versa. This mapping 
is of course one to one, and is 
carried out by the DISPLAY 
subroutine whenever the 
internal data is changed. As 
with LGET and LPUT, 
DISPLAY is left to a future 
LIFE Line for its details. 


What Does it Take to Move 
the Cursor? 


Since the cursor position is 
maintained by the values of 
XCOL and YROW, the 
movement of the cursor is 
simplicity at its essence: To 
move the cursor, all you have 
to do is change the value of 
XCOL, YROW or both! The 
interactive graphics portion 
of KEYBOARD. INTER- 
PRETER has as its primary 
concern the various ways of 


Fig. 2. An overall view of the KEYBOARD. INTERPRETER. This isa 
flow chart of the control algorithm for the LIFE application's 
KEYBOARD INTERPRETER routine. Fig. 3 shows the same informa- 
tion in the form of a procedure-oriented language. 


KEYBOARD 
INTERPRETER 


OLDKEY = NULL 
GO - FALSE 


5. DO UNTIL 
OLDKEY = NULL 


TIMEOUT - 
LONGTIMEWAIT 


s 
Loop actively blinks 
the cursor while waiting 
for non-null key code... 
(This branch is not taken 
in case of repoated kay.) 


CALL 
CURBLINK 


REPEATWAIT 
(TIMEOUT) 


^^ 
РА 
/ 
‚ 


TIMEOUT = 
SHORTIMEWAIT ` 
Time out between 
repeated operations starts 
out equal to LONGTIMEWAIT, 
set to SHORTIMEWAIT after 
tha second time delay. 


OLDKEY = KEY 


RETURN 
TO LIFE 
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The simultaneous advantage 
and disadvantage of the 
multiple conditional test 
method of decoding: It 

is a plodding (but straight- 
forward) approach which 
squanders memory resources. 


changing the values of these 
two crucial variables — while 
possibly leaving a trail of 
changed data points in 
LIFEBITS. Fig. 1 illustrates 
several of these changes — 
— To move the cursor up, 
Y ROW is incremented. 


— To move the cursor 
down, YROW is 
decremented. 


— To move the cursor left, 

XCOL is decremented. 

— To move the cursor right, 

XCOL is incremented. 

— To completely redefine 

the column of the cursor, 

the ENTRY register 15 

transferred to XCOL. 

— To completely redefine 

the row of the cursor, the 

ENTRY register is 

transferred to YROW. 
KEYBOARD_INTER- 
PRETER performs these 
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actions at the whim of the 
user via commands entered at 
the keyboards of the system 
— with the flashing cursor 
mark on the screen showing 
the results. 


The ENTRY Register 


In order to provide a 
means of entering 8-bit 
integers into the program for 
control purposes, the 
software of KEYBOARD. 
INTERPRETER maintains a 
numeric input area called 
ENTRY. Whenever an ASCII 
character is sent to the 
program which cannot be 
decoded by DECODE' 
COMMAND table, the last 
resort is to call DEFAULT. In 
DEFAULT, the recover 
assumption is to interpret the 
unknown command as a 
numeric digit (О to 9) and 
push it into ENTRY. A 
routine in DEFAULT 
performs a BCD to binary 
conversion of the ASCII 
character after it has been 
trimmed to the range O to 9. 
Later, when the user wants to 
define XCOL, YROW or N, 
the commands X, Y and N 
respectively are used to 
transfer ENTRY to one of 
the other registers, after 
which ENTRY is set to O in 
preparation for re-use. It is 
important to emphasize that 
ENTRY is a binary number. 
When decimal digits аге 
entered by the user, the input 
routines convert the digits 
into the appropriate binary 
number and decimally shift 
the significance of the 
previous value. 


The N Register 


In LIFE Line 2, the LIFE 
program given in Fig. 3 
references a variable called N. 
This N is used to control the 
number of times 
GENERATION is called. N, 
like XCOL and YROW, is a 
"software register" in the 
LIFE program which may be 
set by a user command. The 
"N" command is what is used 
to transfer the ENTRY value 
to N for use in controlling the 


Fig. 3. The KEYBOARD INTERPRETER routine’s overall flow, 
expressed in a procedure-oriented language. Note that the interpreta- 
tion of the "DO WHILE” differs from a "DO UNTIL" — the former has 
its test prior to execution of the loop statements, and the latter has its 
test at the end of the loop. Nesting of the DO groups is indicated by the 
indentation of lines. 


1 KEYBOARD INTERPRETER' 

2 PROCEDURE: 

3 OLDKEY NULL, 

4 GO FALSE, 

5 DO UNTIL GO = TRUE; /* LOOP UNTIL DONE WITH INPUTS */ 

6 DO WHILE NOTREADYIKEYBOARD! - TRUE; 

7 CALL CURBLINK; /* THIS LITTLE LOOP WAITS */ 

8 OLDKEY NULL; /* FOR A KEYSTROKE AND BLINKS */ 
9 TIMEOUT LONGWAIT, /* THE CURSOR ALL THE WHILE "7 
10 END; 

11 KEY - INPUTIKEYBOARDI: /* WHEN READY, READ KEYBOARD 
12 CALL DECODE; /* EXECUTE COMMAND */ 

13 CALL REPEATWAIT(TIMEOUT); /* DON'T LOOK TOO SOON '/ 

14 IF KEY = OLOKEY THEN /* SHORT DELAY AFTER FIRST */ 
15 TIMEOUT SHORTIMEWAIT; /* TWO OPERATIONS DONE ` 

16 OLDKEY = KEY: 

17 END: 


18 CLOSE KEYBOARD INTERPRETER: 


Subroutines Referenced by KEYBOARD. INTERPRETER: 


NOTREADY = a function subroutine (also referenced by INPUT) 
which is used to control an idle loop. It returns FALSE as its value if 
the selected device (in this case, KEYBOARD) is ready for input, and it 
returns TRUE as its value otherwise. 


CURBLINK = a subroutine which “blinks” the cursor on for a fixed 
period of timc, followed by a fixed period of “off” time. Since it must 
be called cach time a single blink is required, this implements the 
“active control” feature mentioned in LIVE Line 1. 


INPUT = a function subroutine which returns the current input data 
value for the selected device (in this case, KEYBOARD). INPUT has its 
own wait loop referencing NOTREADY – which for KEYBOARD 
INTERPRETER is redundant, but is not redundant in general. 


DECODE = the major subroutine of KEYBOARD_INTERPRETER. 
This routine analyzes KEY based upon tables and the previous inputs to 
the program from the operator. Using this analysis it will sclect the 
appropriate subroutine to execute. These “command subroutines” will 
in turn affect LIFE program data and the course of the LIFE program's 
execution. 


REPEATWAIT - a subroutine designed to call CURBLINK a number of 


times specified by TIMEOUT. This implements a delay between 
multiple responses to the same key held down continuously. 


Data (8-bit bytes) used locally by KEYBOARD INTER- 
PRETER: 


OLDKEY = 8-bit value of the last previous keystroke. 

NULL = 8-bit value of a null key pattern as read from the keyboard. 
TIMEOUT = 8-bit value of the current repeat key time delay. 
SHORTIMEWAIT = the timeout parameter used after the first delay in 
a multiple input of the same key. This specifics the rate of rapid motion 
of the cursor under manual control. 

LONGTIMEWAIT = the value of the timeout parameter used for the 
first delay following a key entry. A longer wait is required at first to 
avoid false duplication of keystrokes for heavy-handed players of the 
game. 

Data (8-bit bytes) used by KEYBOARD INTERPRETER and 


shared with the whole program. See Table II for explanations. 


GO, DONE, TRUE, FALSE, KEYBOARD, COMMAND, KEY 


Mi 


extent of the next run. Since 


this application uses 8-bit 
data, the limit is 255 
generations of LIFE at 
present. 


Figuring Out What the User 
Said 

The KEYBOARD. 
INTERPRETER routine 
serves the function of 
controlling the input of 
information to these software 
register апа to the 
LIFEBITS grid. The routine 
itself is a loop which executes 
over and over until the user is 
ready to run the 
GENERATION algorithm for 
one or more generations. The 
KEYBOARD 
INTERPRETER terminates 
for one cycle of LIFE when 
the user inputs a “С” control 


command which is 
interpreted semantically as 
“GO generate N generations”. 
The flow chart of the 
KEYBOARD_INTER- 
PRETER logic is illustrated in 
Fig. 2, with the equivalent 
procedure-oriented language 
version shown in Fig. 3 as a 
detailed reference. In Fig. 2, 
line numbers are provided for 
comparison to Fig. 3. 
Execution of the 
KEYBOARD. INTER- 
PRETER begins with some 
initialization statements. The 
values of GO and OLDKEY 
are set at the start of 
execution (lines 3 and 4). 
These values will be changed 
during execution of the 
KEYBOARD INTER- 
PRETER based upon input 
data. OLDKEY is used to 


detect duplications of 
keyboard input which occur 
when a key is held down for 
continuous operations. After 
a given KEY is held down 
continuously for two 
operations, the repetition 
goes into a high speed mode 
with SHORTIMEWAIT 
controlling the delay between 
operations. GO is the control 
variable which is used to 
govern whether or not the 
loop is to continue — it is 
initialized to FALSE and will 
be changed to TRUE when 


the "G" user command is 
decoded. 

Programs Are the Willing 
Servants of the Noble User? 


Interaction of 
programmed computers with 
human beings is often a 


waiting game. This waiting 
game is aptly illustrated in 
the loop which checks for 
user input keystrokes at lines 
6 to 10 of the KEYBOARD 
—INTERPRETER routine. 
The function NOTREADY 
(KEYBOARD) is a notational 
convention used to indicate a 
test for the keyboard ready 
condition. Like a ready and 
willing servant, the computer 
program keeps marking time 
in this loop until the user — 
you or | — has given it a 
character to digest. Two 
statements are included in 
this loop for the purpose of 
coordinating multiple 
keystroke conditions: Setting 
OLDKEY = NULL is used to 
re-establish a null history if 
the program ever has to wait 
(it never waits when keys are 


Table I. ASCII Command encoding for the LIFE application. This is an initial specification of the command codes used to control the 
KEYBOARD INTERPRETER routine's effect. The command table locations go up by three as in Fig. 4. No addresses for the command 
subroutines are given yet — these will be filled in when the program is compiled for your computer. Command table locations and command 
characters are given as hexadecimal numbers. 


Command Table — Command 
Location Character 
00 Xx 
03 47 
06 49 
09 53 
oc 52 
OF 58 
12 59 
15 4E 
18 43 
1B 45 


ASCII 
Key 


??? DEFAULT 


Command 
Subroutine 


G RUN 

I INITIALIZE 

S SAVELIFE 

R RESTORELIFE 
X SETXLOC 

Y SETYLOC 

N SETNGEN 

C CLEARS 

E LIFEDONE 


Meaning of the Command (its ‘‘semantics’’} 


The first table position is the "default'' routine position, which is called 


when no other matching key is found in the table search. 


The “run” command which sets a flag called GO in order to end the 


KEYBOARD, INTERPRETER and have LIFE call the GENERATION 


routine. 


The “initialize” command to set up the screen with predetermined 


patterns selected by additional keystrokes. 


The “save” command to dump the current screen content onto a 


waiting audio cassette or other mass storage device. 


by “S”. 


XCOL. 


YROW. 


The “restore” command to recover a screen pattern previously saved 


The "set X” command to explicitly set the horizontal cursor location, 


The "set Y” command to explicitly set the vertical cursor location, 


The “set N'' command to explicitly set the generation count for 


subsequent execution with the “G” command. 


The "clear screen” command to wipe out all data and place the cursor 


at the center. CLEARS requires confirmation with a second S key 


stroke to avoid accidental clears. 


The “done” command is an E followed by an L (for End Life.) The 


second character confirmation is checked by LIFEDONE. 


Note that the ASCII characters 0 to 9 are used to define the "current input" maintained by software in ENTRY. ENTRY may then be 
transferred to N, XCOL, or YROW by the N, X and Y commands respectively. 
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held down continuously). 
TIMEOUT = LONGTIME- 
WAIT re-establishes a longish 
debounce period between key 
interpretations following a 
series of continuous inputs. 
The program of course thinks 
that if a key is not ready 
upon restarting the main loop 
at line 6 it could not possibly 
be a repeat. While idling and 
waiting for your interactive 
whims, the computer 
program is not completely 
devoid of useful work. It calls 
CURBLINK once each time 
around the wait loop in order 
to flash the cursor actively on 
the screen. 

Finally, after some time of 
unspecified duration, you 
make up your mind to input 
a key. This has one major 
effect upon the program: The 
next time around the loop at 
the test of the WHILE 
condition, a result of FALSE 
ends the loop. Execution 
then flows from the DO 
WHILE (line 6) to line 11 
where the KEY is read from 
the waiting keyboard device 
by a subroutine called 
INPUT. 

With KEY defined, 
DECODE is the next item on 
the agenda. DECODE is one 
of the major subroutines of 
KEYBOARD_INTER- 
PRETER, a routine which 
takes KEY and compares it to 
a COMMAND table. The 
result of the COMMAND 
table search is execution of a 
“command subroutine” if a 
match is made, or execution 
of a DEFAULT routine if no 
match to KEY is found. 
Upon return to 
KEYBOARD_INTER- 
PRETER (all subroutines by 
nature return to the caller 
except in very rare cases), the 
flow of control reaches the 
REPEATWAIT call using the 
current value of TIMEOUT. 

During normal execution 
of single isolated commands, 
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the TIMEOUT value is 
LONGTIMEWAIT — which 
might be chosen to be from 
0.1 to 0.5 seconds. This 
TIMEOUT sets the minimum 
time between the first 3 
keystrokes of а repeated 
sequence. But, after two long 
delays have been executed, 
the match of OLDKEY = 
KEY is detected at line 14 
and TIMEOUT is changed to 
SHORTIMEWAIT allowing a 
speedy repeated motion case. 
SHORTIMEWAIT might be 
chosen in the 0.05 to 0.1 
second range for rapid 
motion. The values of these 
two motion control constants 
are left unchosen for now, 
and can be figured out as 
binary integers to be used in 
REPEATWAIT when details 
of the CPU and 
REPEATWAIT routine are 
filled in. Note that if fast 
operation is desired 
immediately after the second 
operation of a repeated 
sequence, then line 13 of Fig. 
3 should be moved to a 
location between lines 15 and 
16. 

In order to control the 
repeat logic, the statement 
OLDKEY=KEY is executed 
at line 16 so that the last 
input will be retained for 
comparison purposes the next 
time around. 

The KEYBOARD. 
INTERPRETER routine 
finishes up with the CLOSE 
statement of LIFE line 18, 
which stands for the end of 
the routine and return to its 
caller. There is one and only 
one caller of this routine, the 
LIFE program itself, 
illustrated in Fig. 3 of LIFE 
Line #2. 


It's АП in DECODE of the 
LIFE Program 


When giving the details of 
the KEYBOARD INTER- 
PRETER logic, the principle 


While idling and waiting 
for your interactive whims, 
the computer is not com- 
pletely devoid of useful 
work. It calls CURBLINK 
once each time around the 
wait loop in order to 
seductively flash its cursor 
on the screen. 


Fig. 4. Decoding by multiple conditional tests. This method of 
decoding keystrokes and activating routines in software is most 
efficient when a small number of possible commands is involved. 


START 


FIG. 5 
DETAIL 


__} 


CALL 

G ROUTINE 
CALL 

H ROUTINE 


CALL 

? ROUTINE 
CALL 

? ROUTINE 


“NONE OF 
THE ABOVE” 


CALL 
DEFAULT 


Fig. 5. Typical code for a single conditional test in the scheme of Fig. 4. 
The example here is using Motorola 6800 system mnemonics. This 
example assumes accumulator A is set up with the character being 


decoded. 


of keeping the program 
design locally simple results 
in a CALL DECODE at line 
12. Whenever some 
subroutine is left unspecified 
except for its inputs (KEY 
for DECODE) and its outputs 
(a command  subroutine's 
execution), sooner or later 
the details must be filled in. 
In designing a DECODE 
algorithm to fill in this set of 
details, there are numerous 
alternatives. For high order 
language aficionados, 
something called a 
‘computed GO TO" 
(FORTRAN) or “DO CASE” 
(PL/1 family languages such 
as XPL or PL/M) would 
suffice following a table 
search. However, for this 
particular application, a 
slightly lower level approach 


is justified to conserve 
memory. 
Two major alternatives 


come to mind as possible 
ways to map an input KEY 
value into the execution of a 
selected subroutine. The 
simplest (least elaborate) 
“straightforward” approach is 


the method of multiple 
conditional tests. This is 
illustrated schematically in 


Fig. 4’s flow chart, and in a 
concrete form in Fig. 5’s 
example of a segment of the 
typical conditional test. In 
this approach, each possible 
command code is tested in 


turn by the routine. 
Eventually, all the explicit 
possibilities will have been 


exhausted if no match is 
found. Then, if “none of the 
above" match the KEY input, 
a DEFAULT routine is called. 
The main advantage of this 
approach is also its 
disadvantage: It is a plodding 
and straightforward approach 
which squanders memory. 
While the code’s intent is 


obvious, it requires — in the 
example of Fig. 5 — a total of 
8 bytes per test. 

There should be a better 
way -— comparisons and 
branches are repeated in this 
method. The segment of 
generated code and_ its 
corresponding  procedure- 
oriented language version in 
Fig. 5 shows four instructions 
which are repeated over and 
over but with varying data 
(the character being 
compared and the address of 
the subroutine). Why not put 
the instructions in only once 
and tabulate the variable 
data? There might be a saving 
of memory if this table driven 
approach is used instead. 

Fig. 6 illustrates the 
concept of an alternative 
structure, the "command 
table," which will result in a 
lower memory requirement 
once the number of 
commands to be tested 
exceeds some break even 
point. In this concept, the 
changing data for each test is 
stored in the table, and the 
program to go along with it 
uses a looping technique to 
scan that table. The changing 
data for tests comprises: 

— The command character. 
This is the keyboard code 
which is matched against 
the actual KEY input. 
— The command 
subroutine. This is the 
address of the subroutine 
which will be called if KEY 
matches the corresponding 
command character. 
The table is organized in 
3-byte groups consisting of a 
command character followed 
by its subroutine address. 
Note that on first inspection, 
this form of DECODE 
requires only 3 bytes of 
storage per test versus the 8 
bytes in the example of Fig. 


Mnemonic 
СМРА # 'G 
BNE *+4 
JSR GROUTINE 
RTS 


Comment 
Compare A to literal 
Branch around JSR and RTS 
Call the G subroutine 


Return from decoder rather than 
continue the testing 


Total number of bytes per test. 


This is the “generated code" of the following statements in the 
procedure-oriented language used for LIFE Line examples: 


IF KEY = 


'G' THEN 


DO; /* HAVE MADE A MATCH */ 
CALL GROUTINE; 
RETURN; /* FROM DECODE COMPLETELY */ 


END; 


Relative 
Address 


3n 


Зп+1 


Зп+2 


3(0+1) 


3(п+1) +1 


3in*1) +2 


Content 


UNUSED 


Default Address 


Address of “G” 
Command Subroutine 


Address of “Н” 
Command Subroutine 


Fig. 6. The Command Table 
Concept. By storing the character 
(keystroke) being decoded, 
followed by the address of its 
routine, only three bytes need be 
used for each routine which could 
be decoded. Allowing for the 
overhead of a longer decode 
algorithm (specified once), the 
command table method will prove 
more compact when the number 
of commands get larger than four 
or five. 
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reassemble the whole routine 
(a pain in small systems 
work). In contrast, to modify 
the table driven version, | 
only have to alter the table 
itself, and the variable which 
specifies the table's length. 
But this is a minor point in 
addition to the major 
memory conservation 
argument for the table driven 
approach. 

The actual algorithm for 
DECODE is shown in a 
procedure-oriented language 
in Fig. 7. The scan of the 
table is a DO FOR loop with 


which potentially variable 
data is completely segregated 
off in the table. This achieves 
an often desirable end of 
separating data from 
instructions. In the multiple 
conditional test version, the 
data of the DECODE is 
embedded right in the 
DECODE: instruction stream, both as 

PROCEDURE: /* TO FIGURE OUT WHAT USER SAID */ the literal value of the 

/* COME HERE WITH THE KEY TO THE COMMAND */ character being tested and as 

DO FOR | = З TO  ЕМСТНІСОММАМО) BY 3; /* SCAN TABLE */ the address of the routine 


IF KEY = СОММАМР(!) THEN b ` | d. If 1 
DO, /* МОМ! | GOT A MATCH | GOT A MATCH! '/ eing se ected. want to 
modify the multiple 


{= 1117; /° POINT TO ADORESS ENTRY */ 
conditional test version, | 


CALL CALLXICOMMANDüU!; 
{7 NOTATION FOR CALL OF SUBROUTINE, INDEXED */ must certainly recompile or 


RETURN; 
/* THIS FORCES EXIT FROM DECODE */ 
END; 
/* ONLY GET HERE IF NO MATCH IN TABLE */ 
CALL CALLXICOMMAND();/* CALL DEFAULT FROM TABLE "/ 
END; 
CLOSE DECODE, 


Fig. 7. The Command Table DECODE routine specified in a procedure 
oriented language. 


Data (8-bit bytes) used locally by DECODE: Notes on Notation: 
Concerning Indentation: The listings of procedures for 
the LIFE program make use of an indentation 
convention to help show the structure of the routines. 
The significance of the indentation is that it shows the 
opening and closing of various local software 
constructions and in so doing helps convey the meaning 
of the program to human readers. Note how the 
statements from line 7 to line 11 of DECODE in Fig. 7 
ure indented one level compared to the DO (line 6) and 
END (line 12) statements. This indentation shows that 
lines 7 to 11 are part of the DO... END construction 
which is executed if the test on line 5 gives a true result. 


I= temporary used for loop control and indexing. 


Data (8-bit bytes) used by DECODE but shared with the 
whole program. For details see Table II. 


COMMAND, KEY 


Subroutines referenced by DECODE: 


DECODE does not use any "real" subroutines, but does use the 
following two notational conventions which look like subroutines. 


LENGTH(COMMAND) stands for the length (in bytes) of the 
COMMAND table. When you know what it is, you put in the value. 
The notation “/*” followed by arbitary remarks and 


then a “*/” is the "comments" convention used in these 
examples. This convention is stolen from the PL/I 


CALLX(X) is used to denote using the two bytes starting at the 
address X as the address of a subroutine to be called. This is an 
indexed subroutine call effectively. For a Motorola 6800 CPU, this 
would be performed by an LDX instruction indexed off the 
COMMAND table position, followed by a JSR instruction with the 
indexed addressing mode. 


family of languages. 


Concerning names of variables: With each procedure 
specified in LIFE Line, data ís separated into two 
categories: Local data is used only within the procedure 


considerably less than 50 question. Local data may have a name which duplicates 


5. For a 10 command table, 


this would be a 50 byte 
saving at first inspection. 
However, the 50-byte figure 
does not take into account 
the longer looping routine 
required to scan the table and 
indirectly jump when a match 
is found. But for 10 
commands (the number 
found in Table I) this 50 byte 
saving potential goes a long 
way. | expect the actual 
DECODE routine of the table 
driven variety to be 
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bytes in length when it is 
generated for the 6800 
system instruction set used as 
the straw-man in Fig. 5. PH 
leave the final conclusion on 
that to a later LIFE Line. 
There is an additional 
advantage to be obtained 
from the table driven 
method. This is an advantage 
which concerns some of the 
finer points of programming: 
The table driven method 
results in "pure code" in 


names used in other procedures, but is always qualified 
by its local nature. Thus "I" in GENERATION (Fig. 6, 
LIFE Line 2) is a different data location in memory than 
the "I" in DECODE (Fig. 7, LIFE Line 5) Data 
shared with the rest of the program, which is often 
called global data in programming terminology, is in 
contrast defined universally for LIFE. Global data is 
summarized for LIFE in Table II. Thus whenever KEY is 
referenced (as in KEYBOARD. INTERPRETER or in 
MOVECURS) the same data is intended, since these have 
been classified as shared or global in the notes 
accompanying the program listings. 


the index, 1, running from 3 
(the first entry is reserved for 
the default) to the length of 
the table by 3. When a match 
is found, the 16-bit address in 
the table is used for an 
indirect subroutine call (lines 
7 and 8). For a Motorola 
6800 system, this would be 
accomplished by an indexed 


JSR instruction after loading . 


the index register from the 
table. When the selected 
command subroutine returns 
to DECODE (as would any 
well structured subroutine in 
the same circumstance), the 
RETURN statement is 
executed causing an exit from 
DECODE and resumption of 
the KEYBOARD. 


This is shown notationally in 
a general purpose form with 
reference to the command 
table, but in generating the 
code for the statement of line 
14, a simple call to 
DEFAULT might bc 
substituted. (If the generality 
of the DECODE routine is to 
be preserved for possible use 
with other command tables, 
this optimization would not 
be possible.) 

What about data for the 
COMMAND table? Table ! 
provides a preliminary answer 
to this question by giving a 
list of command table entries 
including relative location, 
the corresponding character 
code, the ASCII key which 


actual programs of LIFE are 
generated for a particular 
computer in a future LIFE 
Line. For now, Table | serves 
to list the areas which remain 
to be covered ‘іп the 
discussion of the 
KEYBOARD INTER- 
PRETER and all its 
subroutines. 

LIFE Line 4 will continue 
the presentation of the 
KEYBOARD INTER- 
PRETER portion of the LIFE 
program. To fill out the 
remaining portion of the Tree 
of LIFE, the next installment 
includes the integration of 
graphics control commands 
into the KEYBOARD . 
INTERPRETER and the first 
hardware details of LIFE — a 


Does Anyone Know What 
Happened to Robert T. 
Wainwright? 


This series of articles 
inadvertantly duplicated 
the name of Robert T. 
Wainwright's LIFELINE 
newsletter, published 
through 1973. Thanks to 
Bob Albrecht of People's 
Computer Co. for sending 
us his copy of LIFELINE's 
last issue. Does anyone 
know where Mr. 
Wainwright is now (he's no 
longer at the address given 
by Charles A. Dunning Jr. 
in the Letters column), 


INTERPRETER at the calling 
point. If no match is found, 
the loop eventually runs out 
and line 14 of Fig. 7 is 
rcached, where the 
DEFAULT routine is called. 


invokes the command, the 
name of the subroutine and a 
verbal description of the 
subroutine. This table will be 
used as the basis for creating 
a detailed data table when the 


simple circuit which 2nd is LIFELINE still 
combines an ASCII keyboard being published? 

input with the special 

purpose controls for an 


interactive cursor. ж 


Table II, Global Data. Data which is shared by an entire program or application is often called "global". The word global is used to indicate the 
widespread effects of such data in the program's execution. Many procedures will alter and change such data. This table summarizes the global data 
variables of the LIFE application as used in procedures given in LIFE Lines #2 and #8. 


COMMAND = the table of commands interpreted by DECODE, 
containing the ASCII codes of command keys and the addresses of the 
appropriate command subroutine. The format of this table is illustrated 
in Fig. 6. The information content, in preliminary form, is found in 
Table I. 


DONE = the variable used to control continued execution of the main 
LIFE routine (see LIFE Line #2, Fig. 3). 


ENTRY = the entry register used to receive numeric ASCII digits, after 
weighting the previous value in a BCD fashion. While the entry to 
ENTRY of new digits is done ina BCD manner (multiplying by 10 then 
adding the digit’s value) the content of ENTRY is a binary number of 
8-bit precision with values 0 to 255 and is thus not ilself BCD. (BCD = 
"binary coded decimal") 


FALSE = the value “0” (00 hex, 000 octal, 00000000 binary). This 
name is used to indicate the software equivalent of a hardware gate 
input wired to logical zero. 


GO = the flag (value is TRUE or FALSE) which controls continued 
execution of KEY BOARD  INTERPRETER. 


KEY = the 8-bit data area which receives keyboard inputs. 


KEYBOARD = the logical unit number of the keyboard 1/O device. 
This is a bit pattern which specifies the device one is talking to. 


LIFEBITS = the object of the whole exercise — an array of 64 by 64 
bits stored as 64 by 8 bytes. 


N = the variable used to control the number of generations to be 
evolved by LIFE before returning to KEYBOARD INTERPRETER 


graphics control. 


NCMAX = current maximum column index of live cells. 


NCMIN = current minimum column index of live cells. 


NCOLMAX = maximum column index of live cells for active area 
optimization. 


NCOLMIN = minimum column index of live cells for active area 
optimization. 
NROWMAX = maximum row index of live cells for active area 
optimization. 
NROWMIN = minimum row index of live cells for active area 


optimization. 

NRMAX = current maximum row index of live cells. 

NRMIN - current minimum row index of live cells. 

TEMP = 2 by 8 array of bytes containing two 64-bit rows of cells. 
THAT = previous line copy index to TEMP used in GENERATION (see 


LIFE Line #2, Fig. 6). THAT should always have a value of 1 or 0, 
opposite of THIS. 


THIS - current line copy index to TEMP used in GENERATION (see 
LIFE Line #2, Fig. 6). THIS should always have a value of 0 or 1. 


TRUE = the value “255” (FF hex, 377 octal, 11111111 binary). This 
name is used to indicate the software equivalent of a hardware gate 
input wired to logical one. 

XCOL = in the horizontal (column) 
direction. 


the current cursor position 


YROW = the current cursor position in the vertical (row) direction. 
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Microcomputer 


A new six-volume programmed 
learning course from lasis tells 
you EVERYTHING about what 
microcomputers are and how 
you can design and implement a 


you Ч\ 
BLERS 


MN 


VOL V 
ASSEMBLERS AND 
PROTOTYPING SYSTEMS 


xL vou W 


THE B-BIT wICROCS 


microprocessor-based system. 


Since the transistor was invented, 

no single electronics innovation has 

made such an impact as the micro- 

computer. Powered by tiny semiconductor 

chips containing computing elements with 

the same powers and functions previously 

found only in large scale digital computers, 

these dedicated microcomputer systems are 

now being applied to literally thousands of 
applications. Microcomputers are automating 
assembly lines, providing the heart of sophis- 

ticated electronic games, making "intelligent" 
computer peripherals even smarter, and are going 

so far as streamlining the operations of the fastest 
food chains. This revolution is occuring because micro- 
computers are very inexpensive — costing as little as $30 

in production volume— easy to implement into a system, and 
significantly reduce the time and cost of product development. But 
there has been one serious drawback to this exploding industry: 


Training materials and courses in the basics of microcomputer 
technology have been virtually non-existent, and the various 
published manuals and texts have been undecipherable to those 


not already intimately familiar with ultra-sophisticated logic design. 


Once a designer has the hang of it, microcomputer design is a snap. 
But without the fundamentals—never before available in such a 


readable, understandable and simplified format — microcomputer design 


has been unbelievably difficult. The comprehensive, step-by-step six- 
volume Programmed Learning Course on Microcomputers from lasis 


makes the unbelievably difficult almost ridiculously simple. The authors of 


these texts have been involved on a professional level in the micro- 
computer industry since it became an industry. Their direct, first-hand 


experience in the whys, hows, wherefores and potentials of microcomputers 
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Іаѕіѕ Texts: 

1. Binary Arithmetic 

2. Microcomputer Architecture 

3. The 4-Bit Microcomputer 

4. The 8-Bit Microcomputer 

5. Assemblers and Prototyping 
Systems 

6. 8-Bit Assemblers and 

Compilers 


Finally, you can get a comprehensive training course on microcomputers that puts 
all the hard-to-get information at your fingertips in an easy-to-read, easy-to-understand 
and even easier-to-implement manner. You can get it here...now. gsm mm EH ИШ ИШ ИШ Ш 


design is a snap. 
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have made this six-volume collection the most valuable and ioi dts wl 
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meaningful series ever published on microcomputer езет «ы 


design. The books combine the most effective methods of 
programmed instruction with the entire gamut of essential 
information vital to the designer of a micro-based system. 
You begin with the ABC's of microcomputers and go 
through a virtual post-doctoral course...and the 

unique, self-testing programmed learning lasis course 
enables you to understand and absorb every bit of the 
information every step of the way through the six volumes. 


Specific details are provid four j - 
The lasis course gives you more than 700 pages of detailed, p Sare p ed on four of the indus 


illustrated microcomputer information —including more try's most versatile micr ocomputers—the 4004, 4040, 
than 1,700 self-tests you use to evaluate your progress— 8008 and 8080 from Intel Corporation — but the basic 
plus programming and design aids that make the design of design information will apply to any and all micro- 
ical syst ; f : : f Е 
ч аы а processors. The six volumes you receive with the 


course are: 1) BINARY ARITHMETIC; 2) MICROCOMPUTER ARCHITECTURE; 3) THE 
4-BIT MICROCOMPUTER; 4) THE 8-BIT MICROCOMPUTER; 5) ASSEMBLERS AND 
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(After Nov. 30, 1975 price for the complete lasis course will be $124.50, plus $2.50 for postage and handling.) 


Here's my check or money order (no cash, please). RUSH my You can use your BankAmericard or Master Charge, too! 
6-volume Programmed Learning Course on Microcomputers, 
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Flip Flops 
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One of the important 
building blocks in working 
with transistor-transistor logic 
is the flip flop. It is important 
to understand this building 
block if you desire to use it in 
projects of your own. 

The two most common 
types of flip flops are known 
as the JK flip flop and the D 
flip flop. 


JK Flip Flop 

The JK flip flop has four 
or five inputs and one or two 
outputs. The input pins are 
labeled ], K, CLOCK, 
CLEAR and PRESET, and 
the output pins are labeled Q 
and Q which is often 
pronounced as “О bar" or 
"not О”. A typical block 
diagram of a JK flip flop is 
shown in Fig. 1. 

The outputs (Q and Q) can 
be in one of two states: High 
(logic 1) or low (logic O). In 
general, if the Q output is 
high then the Q output is 
low, and vice-versa, if the Q 
output is low then the Q 
output is high. We will often 
refer to the Q output only 
since we know that Q will be 
the opposite. So if we say 


that the output is high it 
means that Q is high and Q is 
low. However, this is not 
always so; on some flip flops 
you may find a Q output 
only, and, as you will see 
further below, both outputs 
may be high or low under 
specific conditions. 


Asynchronous Inputs 


Now that we know about 
the output states, let's discuss 
the inputs to give us the 
desired outputs. The PRESET 
and CLEAR pins are known 
as asynchronous inputs. 
Asynchronous means that 
these inputs do not depend 


(INPUTS) 


Exposed 


upon the timing derived from 
the clock pulses. 

With almost all flip flops a 
low PRESET will take Q to 
high, and a low CLEAR will 
take the Q to high. With both 
PRESET and CLEAR low 
both Q and Q will be high. 
This is the only time when Q 
and Q are not opposite from 
each other. If both PRESET 
and CLEAR are high, then 
the control of the output is 
given to the J, K and CLOCK 
inputs. The relationship 
between the asynchronous 
inputs and the output is 
shown in the truth table of 
Fig. 2. 


(OUTPUTS) 


Fig. 1. The JK flip flop block diagram. 


Fig. 2. Truth table of a JK flip 
flop responding to preset and 
clear. 


Synchronous Inputs 


The | and K inputs are 
synchronous inputs. 
Synchronous means that they 
depend on the CLOCK for 
operation. 

For most JK flip flops a 
simple set of rules apply to 
the synchronous inputs, but 
not all flip flops are standard. 
There are several variations 
on the timing when the chip 
accepts inputs and when the 
output changes. 

The most 
input-output relation is 
known as the rising-edge 
triggered flip flop. The 
rising-edge triggered flip flop 
derives its name from the fact 
that it changes its output 
states only when the CLOCK 
level rises from low to high. 
Of course, the output states 
depend on the configuration 
of the J and K inputs. Fig. 3 
illustrates the changes of the 
Q pin depending on the levels 
on the J and K pins: When 
both J and K are low, Q does 
not change; when both are 
high, Q changes into its 
opposite state; with Ј being 


common 


low, 
assumes a low level, and when 
J is high, but K is low, Q will 


and K being high, Q 


take on a high level. 
Remember, though, that this 
change can happen only if the 
CLOCK input rises from low 
to high, and, as was shown in 
conjunction with Fig. 2, 
when both PRESET and 
CLEAR are high. 

The less frequent type of 
input-output relation is 
known as the falling-edge 
triggered flip flop. This flip 
flop resembles the first, 
except that the output 
changes to the condition 
selected by the ] and K 
inputs when the CLOCK level 
falls from high to low. 
Everything else remains the 
same. 

It is easy to change the 
operation of a falling-edge 
triggered flip flop to that of a 
rising-edge triggered flip flop. 
All that needs to be done is 
to invert the input to the 
CLOCK. The inverter shown 
in Fig. 4 changes a high level 
to a low level, and vice versa; 
a rising-edge triggered flip 
flop can be changed to a 


Fig. 3. Truth table of a JK flip 
flop for synchronous (clocked) 
operation. 


INVERTER 


Fig. 4. Inverting the clock input 
converts rising edge-triggergd 
operation into negative edge- 
triggered operation and vice versa. 


PRESET 


OUTPUT OUTPUT OUTPUT 
[^^ [5s [omes 
CLOCK | | | | 
PULSE 
INPUT NEW INPUT NEW INPUT 
ACCEPTED ACCEPTED ACCEPTED 
Fig. 5. Timing of a negative clock 
pulse master/slave flip flop. 
INPUT NEW INPUT NEW INPUT 
Ime X ined 
CLOCK | | | | 
PULSE 


Louer Lom -— 


CHANGES 


Fig. 6. Timing of a positive clock 
pulse master/slave flip flop. 


fallingedge triggered flip 
flop, and vice versa, by means 
of the inverter. 

A third type of input is 
known as the negative clock 
pulse master/slave flip flop. 
With this flip flop the inputs 
are applied to the J and К 
pins when CLOCK goes low 
and change their outputs 
after the rising edge of the 
clock pulse (see Fig. 5). 

The clock pulses should be 
made as short as possible and 
the time between clock pulses 


CHANGES CHANGES 


as long as possible. This will 
increase immunity to 
alternating current noise and 
accommodate all ripple delay 
between clock pulses. 

A fourth type of input is 
the positive clock pulse 
master/slave flip flop. This 
flip flop accepts inputs when 
CLOCK goes high and 
changes output when CLOCK 
goes low (sce Fig. 6). The 
pulses should be made as 
short as possible for the 
above mentioned reasons. 
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CLOCK K K K Q 


Vec PRESET 


NC. CLEAR J J J Q GND 


Fig. 7. Pinout of the 7472 IC, a positive clock pulse master/slave flip 
flop. (Top view ) 


Vec PRESET CLOCK кг KI 


GND 


Fig. 8. Pinout of the 7470 IC, a positive edge triggered flip flop. (Top 
view) ` 


CLOCK, 


CLEAR, КА Vee 
+5V 


CLOCK, 


Fig. 9. Pinout of the 7473 IC, a dual positive clock pulse master/slave 
flip flop. (Top view ) 
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Variations on the Four Flip 
Flops 


One of the confusing 
aspects with flip flops is that 
they differ in the logic 
controlling the J and К 
inputs. Some have AND/OR 
logic circuits accepting several 


distinct inputs, and others 
have an inverter before the J 
or K inputs. 

If we look at some 


diagrams of flip flop ICs, 
their operation will be easier 
to understand. 

The 7472 in Fig. 7 is a 
single JK flip flop of the 
positive pulse master/slave 
type. 

The 7472 uses gates on the 
J and K inputs. In order to 
get a high level on the J input 
of the flip flop a high on all 
three J inputs of the IC (pins 
3, A and 5) and the clock (pin 
12) is required. In a similar 
manner, a high on the K 
input of the flip flop is 
obtained with a high on all 
three K pins (pins 9, 10 and 
11) and the clock of the IC. 

If you have only one J 
input, connect all three | pins 
together, or connect two of 
the J inputs to high, and use 
the remaining input for the 
data input. The same holds 
true for the K inputs. 

The 7470, shown in Fig. 8, 
is a single JK flip flop of the 
positive-edge triggered type. 

The 7470 has identical 
gates and inverters on the J 
and K inputs. For example, 
to get a high level on the ] 
input of the flip flop a high 
on J1 and J2 (pins 3 and 4) 
and a low on J* (pin 5) must 
be received. A low level on 
pin 5 is inverted to a high on 
the input to the gate. 

If you do not need J* or 
K*, connect them to ground. 
If you do not need J1, J2, K1 
or K2 connect them to high. 

The 7473 IC is a dual JK 
flip flop of the positive pulse 
master/slave type. Fig. 9 
shows that this IC does not 
use gating on the J and K 
inputs. 

The two flip flops operate 


separately from each other 
having only the *5 volt Vcc 
and ground in common with 
each other. You may also 
have noticed that Vcc is on 
pin 4 and ground on pin 11. 
This is not the same as on 
most 7400 ICs which have 
Vcc on pin 14 and ground on 


pin 7. So check your 
connections before you apply 
power. 

There are no PRESET 


inputs to the chip, in order to 
allow a 14 pin package. 

If you do need the 
PRESET on a dua! JK flip 
flop, use the 7476 available in 
а 16 pin package. It is shown 
in Fig. 10. It has independent 
CLEAR and PRESET pins, 
whereas in the 74H78 of Fig. 
11 the CLOCK and PRESET 
pins, respectively, are 
connected. The 74H78 comes 
in a 14 pin package. 

In many circuits the same 
clock operates many flip 
flops and several flip flops are 
cleared at the same time. The 
74H78 is well suited for these 
needs because it saves on the 
number of external 
connections, saves on the size 
of the IC package, and the 
number of pins. 


D Flip Flop 


Let's make опе small 
modification to the JK flip 
flop: An inverter connects 
the K input to the ] input as 
shown in Fig. 12. 

If J is high then K will be 
low, and if J is low, K will be 
high. Since there is only one 
synchronous input instead of 
the two, let's call it the data 
input or D input. 

Some flip flops have this 
modification built into an IC 
and are referred to as D flip 
flops. A typical block 
diagram of a D flip flop is 
shown in Fig. 13. 

The truth table of the D 
flip flop is shown in Fig. 14. 
Remember that the PRESET 
and CLEAR must be high, as 
discussed in connection with 
Fig. 2. The truth table for 
asynchronous inputs applies 
also to the D flip flop. 


Several ICs employ the D 
flip flop. One of these is the 
7474 dual D flip flop. Since 
only one pin is needed for 
data entry to each flip flop 
both preset and clear 
capability can be provided in 
à 14 pin package. The 
diagram of the 7474 is shown 
in Fig. 15. 

The 7475 IC uses a D flip 
flop which is called a latch 
because the CLEAR and 
PRESET pins are absent. The 
CLOCK, PRESET, CLEARg reduction in pins has been 


CLOCK, PRESET, CLEAR, ЈА Vee 
+5 


Fig. 10. Pinout of the 7476 IC, a dual flip flop similar to the 7473 but 
having both PRESET and CLEAR. (Top view ) 


CLEAR, 


DATA, 


+5 
Vee PRESET, CLEAR, ав J a 


эв 


CLOCK, 


carried one step further by 
combining two CLOCK pins 
each. Therefore it is possible 
to put four latches on one 16 
pin IC; the 7475 quad latch is 
shown in Fig. 16. 

This short introduction to 
flip flops, latches and 
integrated circuits should 
help your understanding of 
this building block. With a 
thorough understanding of 
these circuits, you will be 
well on your way to designing 
your own cquipment. ш 


PRESET, Ов Qa 


Ka Qa Qa JA Qg Ов GND CLEAR, DATA, CLOCK, PRESET, 0, [A GND 
Fig. 11. And still another combination - the pinout of the 74H78 has . . 
14 pins with common CLEAR and CLOCK, and separate PRESET pins. Fig. 15. The pinout of the 7474 dual D flip flop. (Top view ) 
— CLOCK — 
QA Qg Qg 488 GND Qc Qc Qp 


CLOCK о! 


Fig. 13. The block diagram of a D 
flip flop. 


Fig. 12. Making a “D” flip flop 
out of a “JK” with an inverter. 
(Top view ) 


Fig. 14. Truth table of a D flip 
flop. 


Fig. 16. Pinout of the 7475 latch (or register) circuits. (Top view ) 
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WHAT SINGLE ELECTRONIC 
MACHINE CAN BE USED TO 
PERFORM/CONTROL ALL 
THE FOLLOWING TYPES 

OF SERVICES? 


Send morse code 
Control repeater stations 
Operate as a calculator 


Receive/send/buffer data 
between a wide variety 
of communication devices 


Monitor instruments 
Control machines 
Sort/compile data 
Test other devices 


7 me SCELBI-8B MINI-COMPUTER CAN ! 


SCELBI COMPUTER CONSULTING, INC.- The company that pioneered in producing the small computer for the 
individual user with the popular SCELBI—8H, now brings you the new SCELBI—8B with increased capability! - 


Like the former SCELBI—8H, the SCELBI—8B is built around the amazing ‘8 0 0 8' "CPU-on-a-Chip" which has been 
revolutionizing the electronics world. 


However, the NEW SCELBI—8B offers extended memory capability at reduced cost! It is directly expandable to 
16,384 words of RAM/ROM/PROM memory. This increased memory capability now means the user has the potential in 
a small and compact computer to support compiler type languages, manipulate sizable data bases for business and 
scientific applications, and support a wide variety of programs including those that take advantage of external mass 
memory storage devices. 

The NEW SCELBI-—8B still retains the outstanding features of its predecessor. Decoding logic for 8 Output and 6 
Input Ports is built into the basic computer. Plug-in capability for 1/О devices is provided on the chassis. A unique, 
simple to operate console that utilizes just 11 switches on the front panel makes the SCELBI—8B a pleasure to use. 

The NEW SCELBI—8B is backed by a line of low cost SCELBI interfaces which currently include: an interface that 
turns an oscilloscope into an alphanumeric display system, low cost keyboard and TTY interfaces, and an interface that 
turns a low cost audio tape cassette into a "Mag-Tape"' storage and retrieval unit. 

Last, but certainly not least, SCELBI has a wide selection of software ready to run on the NEW SCELBI—8B 
including: Editors, Assemblers, calculating programs, I/O and general utility routines. Additionally, SCELB! produces 
publications that can show you how to develop your own custom tailored programs. 

The NEW SCELBI-8B is available NOW. (We have been delivering since June!) It is available in three forms. Ultra-low 
cost "Unpopulated" card sets with chassis kits starting at $259.00*. Complete parts kits for a 1,024 word 
mini-computer as low as $499.00*. An assembled and tested 4,096 word computer is just $849.00*. Interfaces, 
accessories, and software sold separately. > 


(*Domestic prices.) (Prices, specifications and availability subject to change without notice) 
Literature available for S. A.S.E. 


SCEREI COMPUTER 
CONSULTING INC. 


1322 REAR BOSTON POST ROAD 
MILFORD, CONNECTICUT 06460 


I YOU ARE INTERESTED in learning about microcomputers and microcomputer 


programming, Scelbi Computer Consulting, Inc., has some fine publications that can give 
you a real education. 


The Scelbi-8B User's Manual 


is a fine introductory publication that starts by assuming that the reader has never used a computer. It explains how 
a microcomputer is fundamentally organized and it's basic principles of operation. It then provides a comprehensive 
explanation of the entire instruction set used in the Scelbi-BB microcomputer. Next, there is a highly detailed 
section that explains how to operate a Scelbi-8B and provides several sample machine language programs. Another 
section illustrates how easy it is to connect external devices to the computer. Finally, for those interested in the 
technical aspects, there is a large chapter devoted to technical information — including schematics, assembly 
drawings and parts lists for the Scelbi-8B. (Some might actually construct a microcomputer from the information 
available in this manual alone!) Price? Just $14.95 


Machine Language Programming For The "8 0 0 8" (and similar microcomputers) 


This manual was written to provide the reader with the detailed knowledge one needs to know in order to 
successfully develop machine language programs. This information packed publication discusses and provides 
numerous examples of algorithms and routines that can be immediately applied to practical problems. Coverage 


includes: 
*Detailed Presentation of the “8008” instruction set *Debugging Tips 
*Flow Charting *Organizing Tables 
*Mapping *Maximizing Memory Utilization 
* Fundamental Programming Techniques: Loops, Counters, Pointers, Masks *1/O Programming, Real-time Programming 
*Multiple-precision arithmetic *Programming for “PROMS” 
*Floating-point package *Search and Sort Routines 
*Editing and Assembling . . 
Mathematical Operations *Creative Programming Concepts 


Virtually all the techniques and routines illustrated in the manual can also be applied to other similar 
microcomputers such as '8080" systems (by applicable machine code conversion). The price of this exciting new 
manual is a low $19.95. (The floating-point arithmetic package presented in the publication is worth that price 
alone!) 


Assembler Programs For The “8008” 


Discusses a “minimum length” assembler program that can reside in 2k of memory, plus a more sophisticated version 
for those who have additional memory and desire a more powerful version. Included in this manual is a thorough 
explanation of the fundamental concepts of an assembler's operation, details on how to format the "source listing,” 
step-by-step analysis and presentation of subroutines, program flow charts, and assembled listings of the programs! 
Price? A very reasonable $17.95. 


An "8 008" Editor Program 


Describes variations of an "Editor" program that can reside in 2k of memory. Additional memory may be used to 
increase the size of the text buffer. The program enables one to manipulate "text'"' in order to create "source 
listings" or perform other kinds of text preparation. Includes discussion of routines, flow charts, and assembled 
listing. Priced at just $14.95. Prices given are for domestic delivery at book mailing rate. Add $2.50 for each 
publication if PRIORITY air service desired (U.S.) Overseas — include $6.00 for each publication for airmail service. 


SPECIAL (Expires Dec. 31, 1975) 


Order all four publications at once. mention this BYTE ad, and save over 10% 


6909.00 


(Pricing, specifications, availability subject to change without notice.) 


Order direct from: 1322 REAR BOSTON POST ROAD 
SCELBE COMPUTER о" 


MILFORD CONNECTICUT 06460 
CONSULTING INC. 
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Read 


Only 


Memory Technology 


Kead Unly Memories are a useful element of the hardware 
of microcomputer systems. This month, Don Lancaster pro- 
vides information on Read Only Memories — a tutorial article 
taken from Chapter 3 of his forthcoming book, TV Typewriter 
Cookbook, ѓо be published by Howard W. Sams, Indianapolis, 


by 
Don Lancaster 
Synergetics 


Indiana. 


Low cost and compact 
memory components are the 
key to simple and reasonable 
TV typewriter and 
microcomputer systems. 
Today there are many ICs 
available that will cram 


‘thousands or more bits of 


storage in a single package at 
costs of a fraction of a cent 
per bit. The problem is to 
pick the memory components 
that are the cheapest, the 
easiest to use, and the ones 
with the fewest unpleasant 
surprises. 


What does memory do for 
us? Well, it remembers. If it 
remembers extremely well it 
can be used as a fixed logic 


Fig. 1. 


Read Only Memories 


(ROMs) are non-volatile and used 
typically for programming of 
"firm" microcomputer software, 
for fixed lookup tables, or for 
code conversions. 


element or to store an 
often-used software routine. 


An important example of 
this is the character generator 
memory that converts our 
ASCII code into a group of 
dot patterns suitable for 
video use. The same type of 
memory might be used to 
change the keyboard switch 
closures and shift 
combinations into selected 
ASCII codes. We also use 
permanent memory for code 
conversions such as going 
from ASCII to SELECTRIC, 
and permanent memory is 
usually used to store the 
program апа control 
commands for an external 


INPUT 
WORD 
SELECT e————»- 


à 


microprocessor or 
minicomputer system. 


This particular type of 
memory is called a read only 
memory, or ROM. Once 
taught, it does the same thing 
forever, even if supply power 
is repeatedly applied and 
removed. There are several 
ways this memory type can 
be taught. One is to use a 
factory programmed mask at 
the time of manufacture. 
Another is to use some field 
programming technique such 
as melting internal silicon or 
metallic fuses. This is handy 
whenever you are doing a 
special, low volume code or 
program, or whenever you 


OUTPUT 
WORD 


OUTPUT 
ENABLE 


aren't sure what you are 
doing is really what you want 
to end up with. Such pro- 
grammuable read only 
memories (PROMs) allow 
customizing for special pur- 
poses. Some of the more 
expensive programmable read 
only memories can be bulk- 
erased through exposure to 
ultraviolet light or X-rays; 
these erasable read only 
memories (EROMs) can be 
re-programmed in the event 
of an error. 

Most read only memories 


can also be called code 
converters or table lookup 
devices, and аге usually 


organized as shown in Fig. 1. 
Each ROM is a fixed logic 
block that has several inputs 
and several outputs. For cach 
and every possible input 
address combination of ones 
and zeros, some unique 
combination of output ones 
and zeros will result. There 
doesn't have to be any 
rational relationship between 
these two code words. Either 
you ог the manufacturer 
decides what these 
combinations are going to be 
at the time the ROM is 
programmed. A ROM is 
completely universal; it's 
inherently set up to provide 
all possible combinations of 
input/output word 
arrangements. When you 
program your ROM, you 
limit these all possible 
combinations to a single 
specific word exchange that 
you want. 

One popular smaller ROM 
arrangement is called a 32x 8 
ROM. This means you can 
program 32 eight bit words. 
Since 32 words can be 
represented with binary 
combinations on five lines, 
this particular ROM has five 
input lines and eight output 
lines. This type of ROM has 
256 possible memory 
locations. At each and every 
location, we have the option 
of permanently or 
semi-permanently placing a 
one or a zero. This leaves us 
with 2256 possible programs 
we can teach our ROM, an 


incredibly large number. The 
only thing that changes with 
a particular program is where 
you put the ones and zeros. 
All the rest of the circuit 
stays the same. 

ROMs work by decoding 
each and every possible input 
state into a one-of-n code and 
then recombining certain 
selected combinations of 
decodings into output words 
using OR circuits. Which 
combinations you use picks 
what the output word is 
going to be. 

There are several ways to 
program a ROM. It can be 
done at the factory where 
metal jumpers are provided or 
omitted to the tune of holes 
or no holes in a mask. 
Factory programming is 
cheap but must be done with 
a high volume product that 
has one internal code that 
lots of users can agree to usc. 
Dot matrix character 
generators, some keyboard 
encoders, trig lookup tables 
for calculators and so on are 
typical factory programmed 
ROMs. Field programmable 
ROMs are programmed by 
the user, or by a distributor 
or someone else who is set up 
to do programming. A 
programmable ROM arrives 
from the factory either all 
ones or all zeros, depending 
on the type. You then do 
something to change thc bits 
you want to suit your code. 
In one type of ROM, fusable 
links are melted. These links 
are made of a metal such as 
nichrome, or of a 
semiconductor such as 
silicon. These techniques are 
most commonly used on 
bipolar or TTL-like ROMs. 
These ROMs are usually fast 
and relatively small. Another 
type of programming injects 
large voltage pulses that 
avalanche charge storage 
areas, electret style. This type 
of programming is used on 
MOS read only memories. 
They are usually slower but 
have more bits available per 
package. 

Some premium ROMs are 
reprogrammable. In one type, 


you take off an opaque lid 
and bulk erase the chip with 
strong ultraviolet light. A 
second type can have ones or 
zeros selectively and more or 
less permanently written into 
it. Reprogrammable ROMs 
cost more but can be used 
over. More important, if you 
make a programming mistake, 
you can reuse the same chip, 
correcting the error later on. 

We can also classify ROMs 
as general purpose devices 
and dedicated ones. A general 
purpose. ROM can be made 
into whatever you like and 
used for just about anything, 
such as for code conversion, 
or to store programs for a 
microcomputer or 
microprocessor. Dedicated 
ROMs are usually part of a 
larger integrated circuit and 
have very specific uses. 
Typical examples are in a dot 
matrix character generator, 
the word converter in a 
premium keyboard encoder, 
and the program storage in 
many calculator integrated 
circuits. 

Let’s see how ROMs work 
and what devices are available 
by looking at two important 


Fig. 2. Removing redundant 
information from the 7-segment 
calculator display code. 


(a) Segment callouts. 


(b) Numerals with segments 
"c" and “d” missing are still 


identifiable. 


"jf you do a PROM 
design and end up with 
a ridiculous number of 
bits, you can almost 
always go through a 
rethinking and 
reduction process that 
will minimize things a 
bunch." 


H 
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“Even with bulk erasable PROMs, a mistake on bit 
+1874 of a 2k PROM can be enough to ruin your whole 


day.” 


————————— 


Fig. 3. ROM-organized logic to convert 7segment calculator code to 


BCD or ASCII code. 


4 LINE TO 
1416 DECODERS 


7-SEGMENT - 


INPUTS 4514 (CMOS) 


64 32 16 8 
ASCII OR BCD OUTPUTS 


uses for ROMs — a seven bar 
to ASCII converter that can 
be used to tie a calculator 
into a TV typewriter or 
microcomputer; and an 
ASCH to SELECTRIC code 
converter that lets us drive a 
Selectric typewriter. 


Seven Segment Converter 


Many calculator chips 
output only a seven segment 
code that is not directly 
compatible with 
microcomputer software 
unless it is changed to a 
Binary Coded Decimal (BCD) 
or ASCII coding. While 
several conversion ICs exist, 
at this writing, they are 
neither cheap nor readily 
available. Can we do the job 
with a read only memory? 

At first glance, it would 
scem that we'd need a ROM 
with seven inputs or 27 = 128 
words minimum. But, with 
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practically every ROM 
application, a little bit of 
rethinking can usually 


drastically cut down the size 
and cost of the ROM we'll 
need. For instance, Fig. 2 
shows how we can simply 
ignore the bottom and 
bottom right segments (‘'c” 
and “d”) of the segment code 
and still have ten distinct and 
identifiable characters. This 
cuts us down to 32 words, 
getting us by with five inputs, 
and one fourth the size of the 
ROM we started with. 

Fig. 3 shows us how we 
might build our own 
"pseudo-ROM'' using some 
CMOS gates and decoders. 
While you would rarely want 
to go this route, it's useful to 
look at since it shows us how 
the real ROMs work inside. 
You might occasionally use a 
circuit like this to verify 
programs and truth tables 


Fig. 4. Single IC 7 segment code converter uses 32 x 8 read only 
memory. 


(a) Circuit using 32 x 8 ROM. 


8256 
ROM 


а 
7 SEGMENT P , BCD 
INPUT c 2 OUTPUT 
d 8 
VALID 
e KP 
f 
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(b) Programming. 
INPUT NUMERAL OUTPUT 
gf е ba kp 8 4 2 1 
00000 - 00000 
0000 1 - 0000 
00010 1 10001 
0001 1 7 1011 1 
00100 — 00000 
00101 - 00000 
00110 - 00000 
00 11 1 - 00000 
01000 - 00000 
01001 - 00000 
01010 - 00000 
0101 1 - 00000 
01100 - 00000 
0 1 1 0 1 - 00000 
01 110 — 00000 
0111 1 0 10000 
10000 — 00000 
10001 - 00000 
10010 - 00000 
1001 1 3 1001 1 
10100 - 00000 
10101 - 00000 
10110 - 00000 
10111 2 10010 
11000 - 00000 
1100 1 5 1010 1 
11010 4 10100 
11011 9 1100 1 
11100 - 00000 
11101 6 10110 
117110 - 00000 
131111 8 11000 


since iL is easy to change. 

Our five input lines 
(ignoring the redundant c and 
d segments) are decoded to a 
one-high-out-of-32 code. For 
cach and every possible input 
combination, one and only 
one of the horizontal rails 
goes to a “1”; the rest stay 
low. The OR gates on the 
oulput re-encode this into a 
1-2-4-8 Binary Coded 
Decimal code. We decide 
what our OR gates do by 
where we put the dot 
connections between the 
horizontal and vertical rails. 
To get from BCD to ASCII, 
we can simply tack a hard 
wired 011 in front of the 
BCD word. 


While we could dream up a 
possibly simpler "logical 
minimum" circuit to do the 
same job, this particular 
circuit has a unique advantage 
— if our OR gates are “wide” 
enough, it will convert ANY 
five bit input word into ANY 
four bit output word, with no 
change in hardware. All that 
changes is the positions of the 
dots. This is the beauty of the 
read only memory — only a 
single integrated circuit is 
needed to do an incredible 
variety of specialized jobs, 
depending only on how you 
program it. 


Fig. 4 shows how we take 
a stock 32 x 8, 256 bit 
Programmable Read Only 
Memory, or PROM, and do 
the whole job with one 
integrated circuit. Since we 
have extra outputs left over, 
we can use one for a ‘‘valid 
keypressed" output that can 
tell the difference between a 
zero code and no key pressed. 
The remaining three outputs 
can be used for detecting a 
"O" output or for other 
housekeeping that’s handy 
when you demultiplex the 
scanning digit outputs of the 
calculator IC. To program the 
ROM, the truth table of Fig. 
4(b) is entered into the 
integrated circuit, selectively 
putting ones and zeros as 
needed. 


MANUFACTURER 


AMERICAN MICRO DEVICES 


HARRIS SEMICONDUCTOR 


FAIRCHILD 


INTEL 


INTERSIL 


MONOLITHIC MEMORIES 


NATIONAL 


NITRON 


SIGNETICS 


TEXAS INSTRUMENTS 


Fig. 5. Some commercially available programmable ROMs. 


Working With PROMs 


Fig. 5 is a listing of some 
currently available PROMs. 
Where two numbers are 
shown, one is usually an open 
collector output, the other 
tri-state. At this writing, 
PROMs cost from $5 
upwards, with surplus 
versions (unused) starting 
at $3. Bipolar PROMs are 
based on a TTL technology, 
usually work off a single *5 
volt supply, and are rather 
fast, typically 50 to 70 
nanoseconds access timo. 
MOS PROMs often take two 
power supplies (*5 and —12 
usually) and are slower, 
typically having a опе 
microsecond access time. 
MOS PROMs are often 
cheaper per bit and many 
MOS types are bulk erasable 
by exposure to strong ultra- 
violet light. A few ultra-fast 
ECL PROMs also exist, but 
are reserved for special uses 
and are expensive. 

Two good choices for 
home brew computing are the 
32 x 8 bipolar PROM such as 
the Intersil 5600 or the 
Signetics 8223; and the 256 x 


PART BITS ORG, TYPE ERASABLE? 
27808, 09 256 32x8 BIPOLAR NO 
27810, 11 1024 256х4 BIPOLAR NO 
1702 2048 256x8 MOS YES 
1256 256 256x1 BIPOLAR NO 
8256 256 32x8 BIPOLAR NO 
0512 512 64x8 BIPOLAR NO 
1024 1024 256х4 BIPOLAR NO 
2048 2048 512x4 BIPOLAR NO 
93421 256 32x8 BIPOLAR NO 
93416,26 1024 256х4 BIPOLAR NO 
93436,46 2048 512х4 BIPOLAR NO 
3601 1024 256x4 BIPOLAR NO 
3602,22 2048 512х4 BIPOLAR NO 
1702 2048 256x8 MOS YES 
3604,24 4096 512х8 BIPOLAR NO 
2704 4096 512x8 YES 
2708 8192 1024xB MOS YES 
5600,10 256 32x8 BIPOLAR NO 
5603,23 1024 256x4 BIPOLAR NO 
5604,24 2048 256x8 BIPOLAR NO 
6330,31 256 32x8 BIPOLAR NO 
6300,01 1024 256x4 BIPOLAR NO 
6305,06 2048 512x4 BIPOLAR NO 
634041 4096 51238 BIPOLAR . NO 
8573,74 1024 256х4 BIPOLAR NO 
5202,03 2048 256х8 MOS YES 
5204 4096 512x8 MOS YES 
7002 1024 512x2 MOS YES 
7002 1024 1024x1 MOS YES 
8223 256 32x8 BIPOLAR NO 
82126,29 1024 256х4 BIPOLAR NO 
82130,31 2048 256xB BIPOLAR NO 
82115 4096 512x8 BIPOLAR NO 
74188 256 32x8 BIPOLAR NO 
74186 512 64x8 BIPOLAR NO 
74287 1024 256x4 BIPOLAR NO 
8 erasable MOS PROM, 


including the Intel 1702 and 
its second sources. 

While you can program 
your own PROM with 
nothing but a power supply 
and a meter, the “zero 
defects" nature of this work 
and its "up the wall" aspects 
turn the job into quite a 
hassle. Even with bulk 
erasable PROMs, a mistake on 
bit 41874 of a 2k PROM can 
be enough to ruin your whole 
day. Instead of this, you can 
buy programming services at 
very low cost from many 
electronic distributors, as well 
as from surplus and computer 
hobby supply houses. 
Programming machines that 
simplify the job a bunch are 
available for several hundred 
dollars. [Once you have a 
microcomputer system up 
and running, it is quite 
possible to construct an ROM 
programming peripheral for 
the purpose of permanently 
burning in your software. 
Local computer clubs might 
consider building the ROM 
burner peripheral and related 
software as an attraction of 
membership . . .cth | 


A quarter's worth of 
gating can cut the size 
of a ROM in half. 


When you design your 
own PROM circuit, be 
absolutely sure your truth 
table is correct before you 
order any programming. The 
program service will only 
guarantee that what you sent 
in is what you get back, and 
nothing more. They have no 
way of second guessing what 
you really wanted. 

If you do a PROM design 
and end up with a ridiculous 
number of bits, you can 
almost always go through a 
rethinking and reduction 
process that will minimize 
things a bunch. Leaving off 
the two redundant segments 
of a seven bar code is one 
obvious example. Other 
possibilities are to put simple 
logic outside the PROM, for 
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Fig. 6. ASCII to SELECTRIC interface using PROM. 


ASCII 
INPUTS 
al О 
a2 О 64X8 
сз О PROM 
аа О 
а5 О АМО 
10 
a70 
IL 
"d 
LOWER CASE LOGIC 
E OPTIONAL 
) > C.R. 
GATING 
CTRL 
LOGIC 
NOR 
often a gate or two can 


significantly reduce the 
PROM size. Bypassing control 
commands around a PROM is 
one way to do this. 
Sometimes symmetry and 
mirror techniques can be 
used, particularly when 
working with trig waveforms, 
music waveshapes, and other 
data tables that have some 
sort of symmetry. In PROM 
microcomputer programs, 
sneaky programming tricks 
can often drastically cut the 
number of steps needed; 
extensive use of subroutines 
is One route to this end. 

In code converter and 
table lookup applications you 
usually address your PROM 
in a random fashion and you 
have no way of knowing what 
is going to be needed next. 
There are other ways to 
address ROMs that open up 
other types of applications. 
For instance, if you 
sequentially clock the PROM, 
changing the address one bit 
al a time at a constant rate, 
you can generate an output 
sinewave or a musical timbre 
waveform. The clocking rate 
wil select the output 
frequency, and you can get a 
symmetrical output by using 
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|5РАСЕ 


АМО 
АМО 
АМО 


ROTATE | 
ROTATE 2 
ROTATE 2A 
ROTATE 5 
TILT I 
TILT 2 
SHIFT 


OUT 


KP TO SPACE 
SOLENOID 


KP TO RETURN 
SOLENOID 


o KP TO PRINT 
SOLENOID 


BALL SOLENOIDS 
ENABLE 


BALL 


PUTS 


an up down counter driving 
the address inputs. Another 
possibility is to let the 
PROM's output set the next 
input address to the PROM, 
or at least influence it. Some 
outside latch or storage is 
needed to prevent ап 
unchecked wild race, but this 
is easily added. 

This particular technique 
is called microprogramming, 
and is, of course, the key to 
calculator and micro 
computer operation. Even 
without a CPU, a PROM plus 
additional logic can be used 
as a programmable controller. 
Loops and branches are easily 
added by external gating and 
using extra PROM inputs. 
Several additional details on 
PROM and ROM design 
appeared in the February, 
1974, Radio Electronics. 

A ROM or PROM can be 
used to change ASCII coded 


signals into SELECTRIC 
outputs suitable for the hard 
copy techniques output if 
you have a converted 
Selectric typewriter. While a 
few ICs are commercially 
available to do this job (such 
as the Fairchild 3512 and the 
National 4230), at this 
writing, it’s much cheaper 
and simpler to program your 
own PROM. You can also add 
custom features of your own, 
such as converting the ASCII 

command into a capital 
“E” and so on. 

Fig. 6 shows us a circuit 
that only needs 512 bits 
worth of ROM and a few 
gates to do the onc-way 
conversion for us. The PROM 
basically works with the 
ASCII 6 bit code of upper 
case alphabets, numbers and 
punctuation. It converts these 
ASCII commands into the 
seven Selectric shift, rotate 


Fig. 7. Listing of ASCII inputs (octal) and Selectric outputs for the PROMs in Fig. 6. 


ASCII 
INPUT CHARACTER 
100 @ 
101 А 
102 B 
103 с 
104 D 
105 E 
106 F 
107 G 
110 H 
111 i 
112 J 
113 K 
114 L 
115 M 
116 N 
117 [s] 
120 P 
121 a 
122 R 
123 S 
124 T 
125 u 
126 M 
127 Ww 
130 x 
131 Y 
132 2 
133 1 
134 \ 
135 } 
136 ^ 
137 - 
ASCII 
65 4 321 
ото то 


SELECTRIC ASCII SELECTRIC 
OUTPUT INPUT CHARACTER OUTPUT 
166 040 SPACE 200 
134 041 ! 177 
140 042 ” 125 
154 043 # 176 
155 044 $ 171 
145 045 % 135 
116 046 & 175 
117 047 ' 025 
141 050 ( 160 
124 051 ) 161 
107 052 174 
144 053 * 106 
151 054 014 
137 055 - 000 
146 056 026 
131 057 А 011 
105 060 0 061 
104 061 1 077 
135 062 2 066 
121 063 3 076 
147 064 4 071 
156 065 5 065 
136 066 6 064 
120 067 7 075 
157 070 8 074 
101 071 9 060 
167 072 : 115 
111 073 ; 015 
164 074 < 027 
111 075 = 006 
145 076 > 127 
100 077 ? 111 
SELECTRIC READING 
SPSH Т2 Т1 А5 R2AR2R! BITS OCTAL 
u oy 104 110 BINARY 
U 1 5 6 OCTAL 


and tilt ball commands. The 
program appears in Fig. 7. 
We've shown it in octal 
coding to make it more 
compact. 

Most of the characters are 
directly converted from 
ASCII to their SELECTRIC 
equivalents. ASCII < and > 
become the Selectric 1/2 and 
1/4 respectively, the ASCII 

N becomes the Selectric d, 
and opening and closing 
brackets are disallowed and 
produce question marks. 
ASCII — | becomes a 
capital "E" 1o indicate 
exponentiation, particularly 
when using the BASIC 
language on a microcomputer 
output display. 

The cighth output of our 
PROM is used to detect an 
ASCII space and break it out 
of the code, for a Selectric 
space is a machine command, 
and an ASCII space is a 
printing character. If a space 
is detected, the keypressed 
output is diverted to the 
space solenoid and the ball 
moving solenoids are 
disabled. 

If a lower case alphabet is 
provided, the input logic on 
bits a6 and a7 detects lower 
case and converts it to its 
equivalent upper case ASCII 
six bit input code and at the 
same time forces the shift 
output line to the lower case 
low state. This is a good 
example of how a quarter's 
worth of gating can cut the 


size of a ROM in half. 
Another Selectric machine 


command we need is areturn 
command to move the ball 
back to the beginning of a 
line. This command can be 
detected with the lower left 
NOR gate (Fig. 6) and used 
to divert the  keypressed 
output to the carriage return 
solenoid, at the same time 
disabling the  ball-moving 
solenoids. If there should be 
any other control commands 
which are to be ignored by 
the typewriter, carriage 
return detection logic 
(OPTIONAL CR GATING in 
Fig. 6) can be added to 
distinguish carriage returns 


Fig. 8. Full function ASCII to SELECTRIC code converter uses larger 


PROM. 


GOES TO "I" ON PRINTABLE CHARACTER; = 
*O" ON MACHINE COMMAND 


from the added control 
commands. 

You can build this ASCH 
to Selectric interface using a 
single 64 x 8 PROM or a pair 
of 32 x 8 PROMs with 
parallel outputs selected by 
the chip enable inputs. Using 
two ICs is sometimes less 
expensive than one larger 
PROM because the smaller 
PROMs are more widely 


available as surplus. Fig. 5 


lists several typical PROM 
parts. 
All Selectric functions 


including bell, tab, backspace 
and index are accommodated 
in the circuit of Fig. 8. It 
takes a PROM of four times 
the size, provides more 
functions, and is a simpler 
circuit than the one shown in 
Fig. 6. The eighth PROM 
output is used to decide 
whether the ASCII code is a 


printed character or a 
machine command (which 
might be ignored). This 


eighth output line feeds back 
to the PROM's eighth input 
line via the resistor-capacitor 
time delay circuit. When bits 
1 to 7 of the PROM input 
represent a printable 
character, the eighth bit 
output line switches to a high 


TILTI 
TILT г 
SHIFT 


O SPACE 
RETURN 


INDEX 
TAB 


BELL 


KP TO 


SPARE 


ROTATE | 
ROTATE 2 
ROTATE 2A | BALL 
ROTATE 5 


OUTPUTS 


MACHINE 


BACKSPACE| OUTPUTS 


PRINT 


SOLENOID 


KP TO MACHINE 
SOLENOIDS 


BALL SOLENOIDS 


level which enables printing. 

The ball output codes are 
the same as in the simpler 
circuit, but their solenoids 
must be disabled when the 
machine command codes are 
received. When a character is 
to be printed, the keypressed 
pulse (KP in Fig. 8) isrouted 
by the upper AND gate 
(enabled by the logical one 
output of the PROM's eighth 
bit) to the print solenoids; 
the ball solenoid enable is 
also taken from the eighth 
PROM bit. The result is 
movement of the ball 
combined with a print stroke. 

If, however, a machine 
command is presented to the 
PROM at the ASCII inputs, 
the eighth bit of the PROM 
output goes low and disables 
both the ball solenoids and 
the gate which would route 
KP to the print solenoid. This 
bit is inverted by the inverter 
to present a logical one level 
to the lower AND gate in the 
figure. This enables the 
keypressed pulse (KP) to go 
to the machine solenoids. 
Any legitimate command 
code will result in selection of 
one of the machine outputs 
in Fig. 8. The 
selected machine output line 


ENABL 


E 


will enable the corresponding 
machine control solenoid's 
driver — resulting in one of 
the machine control actions 
such as a tab. As an example, 
suppose a horizontal tab 
function (HT in ASCII) is 
presented to the PROM: The 
PROM decodes a machine 
command, inhibits ball 
solenoids and the print 
solenoid, presents a decoded 
logical one level to the tab 
solenoid driver, enabling it, 
and routes the keypressed 
signal (KP) to the other tab 
solenoid driver input — 
resulting in a tab action. 
Since the PROM is to be set 
up for only six (or seven) 
legitimate machine 
commands, any unwanted 
ASCII machine control codes 
wili be ignored. 


In this article, we've seen 
some background 
information on ROM 
technology and several of the 
many uses to which ROMs 
can be put in microcomputer 
and logic systems. These are 
by no means the only uses of 
ROMs. The uses of ROM 
technology are for the most 
part limited only by your 
own imagination. ш 
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1974, 
Hewlett-Packard | announced 
their fourth model in a 
continuing series of 
sophisticated pocket 
calculators. This model, the 
HP-65, was unique in that it 
was programmable and used 
magnetic cards to read and 
write user-written programs. 
One of the first questions 
asked about the new machine 
was, “Is it a calculator or a 


computer?" There is no 
question that the HP-65 is the 
most powerful computational 
tool in existence for its size 
and weight, but in terms of 
an Altair 8800, Mark | or 
Sphere microcomputer, how 
does the HP-65 stack up? 


Computer vs. Calculator 


In the classical definition 
of a computer, as described 
by Babbage, the HP-65 is 


THE H-P 65: WORLD'S 
SMALLEST COMPUTER SYSTEM 


On Jan. 17, 


indeed a computer. The 
HP-65 has conditional and 
unconditional branching, data 
storage, and a memory which 
can be used to store a 
program. By today's 
standards a machine is often 
caled a computer or a 
calculator by the task for 
which it is best suited. A 
calculator is best suited for 
numerical calculations, and a 
computer is best suited for 


binary or alphabetic data 
manipulations involving a 
large data base. In this sense, 
the HP-65 is — as it is called 
—a calculator. 

If you are interested in 
computers and programming, 
should you consider the 
HP-65? Most definitely! The 
only negative aspect of the 
HP-65, compared to a typical 
microcomputer kit, is its cost 
(i.e., $795 versus about 
$500). If, however, you 
consider the microcomputer 
complete with an operating 
system and an input/output 
device — but built into a 
pocket-size package, then the 
HP-65 is a very competitively 
priced unit. 

There is no doubt that the 
HP-65 "computer" is the 
easiest to get up and running. 
If your interests are primarily 
of a problem-solving nature, 
and a personal, portable 
computational and 
educational tool will meet 
your needs, the HP-65 is for 
you. 

If your interests tend 
toward programming, the 
HP-65 is an excellent machine 
to learn programming upon. 
If you master memory 
limited (every computer is 
memory limited sooner or 
later) programming on the 
HP-65, you will have an 
excellent background to 
move up to a larger machine 
if you desire. There will be no 
problem selling a used HP-65. 
Just try buying one! 


How Powerful is the HP-65? 


The HP-65 has 100 
memory steps, and 14 data 
registers (four in the stack) 
directly accessible to the user. 
Programs may be linked from 
card to card if efficient 
programming won't allow 
placing all steps on one card. 
Card read time is about the 
same as the dial “0” time on 
an older model telephone. 
Four logical comparison 
operations, two flags, 
decrement counter, 
convenient editing, five 
user-defined keys and merged 
codes which allow two 


keystrokes to occupy only 
one step of memory all 
combine to make the HP-65 
so powerful that it was used 
to backup the on-board 
computer on later Apollo 
missions. Programs have been 
written for the HP-65 to 
perform some amazing 
calculations — and other tasks 
as well. 

Hewlett-Packard has 
nearly 4,000 programs in 
their library, all available to 
HP-65 users. A catalog details 
and classifies each program. 
Hewlett-Packard also offers 
collections of programs in the 
form of PACs containing 40 
pre-recorded cards. To date, 
14 PACs are available, 
covering the fields of finance, 


mathematics, electrical, 
chemical and mechanical 
engineering, medicine, 
surveying, aviation and 
navigation. 

The HP-65 can be 


programmed to: 


a) Play Tic-tac-toe, NIM, 
Bagels, Craps, Ping-pong, 
Slot Machine, Football or 
Hexapawn. Some games are 
cybernetic — one card — 


and will actually learn to 
play a perfect game. 

b) Generate 10,000 digits 
to test a random number 
routine, sort and tally the 
digits 0-9 to check the 
routine's uniformity. 


c) Play word games such 
as Word Squares or 
Hangman. 


d) Generate a table of 
prime numbers. 

e) Solve up to seven 
simultaneous equations in 
seven unknowns. 

f) Design a transistor 
amplifier circuit with all 
calculated values converted 
to EIA standard values. 

g) Teach students 
arithmetic using teaching 
programs that adjust to the 
learning rate of the student. 


h) Compute double 
precision products such as: 


9, 753, 124, 680 
x 9, 375, 168, 024 - 
91,437,182,634, 
021,232,320 


(64-bit arithmetic is not 
enough precision for this 
number-crunching 
application.) The latter is an 


example of the type of 
problems їп which the 
calculator is outstanding 
and the microcomputer is 
marginal. Try an alphabetic 
sort of the names of the 
members of your car pool 
and the situation is reversed. 
Like all electronic 
‘*computers,’? someone 
always applies their machine 
in unusual ways in an attempt 
to solve a problem. For blind 
users a program has been 
written for the HP-65 which 
will produce a tone on a radio 
in the form of coded beeps to 
"spell out" the display. One 
user has applied a program to 
generate points to plot a 
modern art figure. In the 
search of trying to get 200 


steps into a 3100-step 
memory, users have even 
found logic. that wasn’t 


intended to be included in 
the instruction set. Many 
HP-65 users get the most 


from their ‘machine by 
sharing their experiences 
through an organization 


established for that purpose. 
Most computers have users 
groups — for the HP-65 it is 
the HP-65 Users Club. в 
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Build A 6800 System 
With This Kit 


If you are one of the many 


people getting ready to 
purchase one of the 
reasonably priced 
microprocessor system kits 


on the market today, you 
might ask yourself whether or 
not you will be able to start 
entering programs once you 
get it all put together. Of 
course you can always load 
programs and data through 
the front panel programmer's 
console, but most individuals 
aware of the front panel's 
Slow speed and difficult 
readability prefer to use a 


Teletype or low cost video 
terminal such as the TV 
Typewriter II (February 1975, 
Radio Electronics) for data 
and program input/output. 
This is all well and good 
except that in order to attach 
a terminal, you'll have to 
purchase an interface for 
your computer if it is not 
supplied with the basic 
system. In fact you will 
generally need a separate 
interface for each 1/0 
(input/output) device 
connected to your computer. 
This can run your system 
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investment up considerably 
since such interfaces typically 
cost between $75 and $150 
each, and there are more 
surprises yet to come. 

So now you've got your 
computer, with interface, 
attached to your terminal; 
you're ready to sit down, 
power up and start typing in 
your program, right? Well, 
not quite. You see, in order 
to be able to use the terminal 
for either entering programs 
or getting data in and out of 
the computer you must have 
a program resident or loaded 


Fig. 1. Block diagram of the SWTPC 6800 system. The address allocations of the elements of the system are 


noted inside the blocks. 


CPU, 
CLOCK & BUFFERS 
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MIKBUG 
ROM 
E000-E1FF 


USER 
TERMINAL 
{TTY OR RS-232) 


MIKBUG 
RAM 
A000-A07F 


2K BYTE 
RAM 
0000-1F FF 


CONTROL 
INTERFACE 
8004-8007 


into memory telling the 
processor how and what to 
do. Without this software 
(program), you can pound on 
the keyboard all you want 
and the computer won't do 
anything. Computers are no 
smarter than their 
programming lets them be 
and without programming 
they're not very smart at all. 
How do you get this software 
into memory? Well, you 
could load it in from paper or 
cassette tape, that is if you 
have a paper tape reader or 
cassette tape interface 
(another sizable investment) 
or you could enter it directly 
from the programmer’s 
console. The problem here is 
two fold. Software to give the 
terminal reasonable system 
control will probably be 
around 500 words in length. 
This is far too long to enter 
from the programmer’s 
console especially when you 
consider it has to be 
re-entered every time the 
system is powered up or after 
a wayward program 
overwrites any of its allocated 
area of memory. The second 
problem is that few if any of 
the manufacturers supply a 
listing, paper tape or cassette 
tape of such a program to 
begin with. Their terminal 


control routines аге 
contained within 
editor/assembler and higher 


MEMORY BOARD 


CPU BOARD 


MCM6810L1 
128X8 RAM 
MCM6830L 
"MIKBUG'' 
ROM 


level language packages which 
not only must be loaded from 
some kind of tape reader, but 
require from 4,096 to 8,192 
words of memory to operate. 
And you thought the 
interfaces were expensive, 
just check the prices on 8,192 
words of memory. Many of 
the systems now on the 
market are supplied with an 
amount of memory with the 
basic unit which is 
considerably less than what 
might actually be needed for 
useful programming. 

So what's the alternative? 
Well, the system presented in 
this article has been designed 
to eliminate the  afore- 
mentioned problems and 
allow the user to have a 
powerful and fully functional 
system at a minimum cost 
(see Fig. 1). The entire 
system is built around the 
Motorola MC6800 
microprocessor and its family 
of support devices. The 
computer itself is being made 
available in kit form including 
the chassis, cover, power 
supply and all circuit boards, 


MC6800 
PROCESSOR 


parts and hardware necessary 
to build a Motorola 6800 
based microprocessor 
including a 1,024 word ROM 
(read only memory) stored 
operating system with 
128-word scratch pad 
memory, serial interface baud 
rate generator, serial 
interface, and 2,048 words of 
memory for $450. This 
article gives a description of 
the microprocessor and 
mother board. A future 
article will describe the power 
supply, memory and interface 
boards. 


The Microprocessor/System 
Board (MP-A) 

The Microprocessor/ 
System Board (coded MP-A) 
is the primary logic board for 
the system. It isa 5 1/2" x 9" 
double sided plated-through 
hole circuit board containing 
the 6800 microprocessor 
chip, the 6830 ROM which 
stores the  mini-operating 
system and the 6810, 
128-word scratch pad random 
access memory (RAM) 
needed by the ROM. 


"—E————- CONTROL INTERFACE 


MOTHERBOARD 


Ed POWER 


SUPPLY 


There is a crystal controlled 
processor clock driver and 
baud rate generator providing 
serial interface baud rates of 
110, 150, 300, 600 and 1200 
baud for all but the terminal 
control interface which is 
operable at 110 or 300 baud. 
Also provided is a power 
up/manual reset circuit which 
restarts the ROM stored 
mini-operating system 
whenever activated. Full 1/O 
buffering is provided for the 
16 address lines and eight 
bidirectional data lines with 
these and other connections 
made to the rest of the 
system through the mother 
board via a 50-pin connector. 


Power for the board is 
derived from a +5 volt 
regulator fed from the 


system’s unregulated 7 volt, 
10 Amp power supply. 
Average current consumption 
for the board is 0.8 Amps. 
The mini-operating system 
stored in the 6830 ROM on 
this board has got to be one 
of the most outstanding 
features of this system. It is 
through this Motorola written 


Details of the SWTPC 
6800 System. This photo 
illustrates what you see 
when you remove the 
cover of a typical SWTPC 
computer system. This is 
an assembly of the parts 
which come in the MP-68 
kit. 


software package called 
“MIKBUG” that the user can 
1) enter program or data into 
memory from either the 
terminal's keyboard or tape 
(where applicable), 2) jump 
to and execute a program 
loaded in memory, 3) list 
programs or data stored in 
memory, on the terminal or 
tape (where applicable), 4) 
examine and/or change the 
contents of the internal CPU 
registers, 5) examine and/or 
change the contents of 
specified memory locations. 
These operations are 
performed using a 20 mA 
current loop Teletype or an 
RS-232C compatible serial 
ASCII terminal. 

This ROM mini-operating 
system does not have to be 
loaded from tape and it 
cannot be overwritten. lt is 
always there at your 
fingertips — just pressing the 
RESET button or simply 
powering the system up 
automatically restarts this 
firmware (ROM stored 
software). When activated, 
this system responds with a 
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l | i FFFF 


MINIBUG/ 
TEST PATTERN 
(NOT USED) 


EIFF 


MIKBUG 
ROM 


E000 


AOTF 


MIKBUG 
RAM 


A000 


1/0 PORT ВОІЕ 
NO.7 вос 
170 PORT 80lB 
NO.6 8018 
1/0 PORT 8017 
NO.5 8014 
1/0 PORT 8013 
NO.4 8010 
170 PORT 800F 
800C 
170 PORT 800B 
NO.2 8008 
1/0 PORT 8007 
NO.I_CONTRL. 
INTERFACE 8004 
1/0 PORT 8003 
NO.O 8000 
4K MEMORY ТЕРЕ 
NO.7 7000 
4K MEMORY 6FFF 
NO.6 6000 
4K MEMORY SFFF 
NO.5 5000 
4K MEMORY 4FFF 
NO.4 4000 
4K MEMORY 3FFF 
NO.3 3000 
4K MEMORY ?FFF 
NO.2 2000 
4K MEMORY {FFF 
NO. | 1000 
4K MEMORY OFFF 
NO. O 0000 
Fig. 2. SWTPC 6800 


Microprocessor System memory 
map. The 64K address space of a 
6800 CPU is divided up into the 
segments shown here. The first 
32K locations are available for 
user read-write memory. The 
second 32K is devoted to I/O port 
assignments and the requirements 
of the MIKBUG program supplied 
by Motorola. 
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carriage return, line feed and 
then prints a * on the 
terminal at which time you 
may enter various single 
character control commands 
such as M for memory 
examine/change, L for load 
from tape, P for punch or list, 
R for examine registers or G 
for go to and execute a 
loaded program. A program 
debug routine can also be 
implemented by using the 
software interrupt (SWI) 
instruction as a “breakpoint” 
which forces a jump from 
your program to the 
operating system to allow 
you to examine the contents 
of memory and/or the CPU 
registers. All data entered or 


displayed through the 
terminal is in convenient 
hexadecimal (base 16) 


notation. This means you can 
type in a command to load 
address location A00016 with 
9E16 instead of setting 24 
console switches to an 
address of 1010 0000 0000 
0000 with data of 1001 1110 
as must be done with the 
conventional programmer's 
console. Since the operating 
System is stored in ROM, it 
consumes no user RAM 
memory, in fact, it actually 
gives the user a little extra. 
There is a 128-word scratch 
pad memory utilized by the 
operating system for storing 
various addresses and data, 
but there are more than 54 
locations within this 6810 
RAM memory which are 
totally unassigned plus a 
46-word deep  push-down 
stack. АП of this memory is 
in addition to the 2,048 
words (expandable to 4,096 
words) contained on the 
standard memory board. 

Since the terminal 
mini-operating system 
provide the user with 
complete system control, 
there is no need for the 
conventional programmer's 
console. Take note also that 
once system control is turned 
over to your program, the 
control terminal is totally 
available for your program 


and 


input/output. In fact, since 
the character input/output 
subroutines are already stored 
within the operating system 
ROM, they can be used by 
your programs simply by 
loading or storing the 
characters to be handled in 
the proper register and 
executing a jump to 
subroutine (JSR). 

The Motorola MC6800 
microprocessor chip is the 
element around which this 
entire system is built. It is an 
8-bit parallel processor with 
eight bidirectional data lines 
and 16 address lines giving it 
an addressing capability of up 
to 65,536 words. There is no 
distinction between memory 
and l/O addressing on this 
system, therefore, all 
input/output data transfers 
are handled just as are the 
memory transfers. This means 
the 1/O interfaces must have 
their own allocated memory 
addresses where neither ROM 
or RAM memory may be 
located. This may at first 
seem to be a disadvantage 
until you realize that all 
memory handling instructions 
are usable for the interface 
data handling as well, thus 
eliminating the need for 
special data I/O instructions. 
The memory assignments for 
this system have to be made 
as shown in Fig. 2. User RAM 
may be located anywhere in 
the lower 32K (000016 to 
800016) addresses with the 
upper 32K addresses reserved 
for the operating system 
ROM, RAM and interface 
boards. 

There are six 
internal to the MC6800 
microprocessor element 
which consist of the program 
counter, stack pointer, index 
register, accumulator A, 
accumulator B and condition 
code register. The stack 
pointer is a 16-bit register 
used to store the address of 
the push-down stack which is 
located in RAM memory 
external to the MC6800 
microprocessor element. The 
push-down stack itself is used 


registers 


to store the program counter 
and/or processor data during 
branch to subroutine (BSR), 
jump to subroutine (JSR), 
push (PHS) or interrupt 
routines. The index register is 
a 16-bit register generally 
used as an address pointer for 
many processor instructions. 

There are 72 basic 
instructions for the 6800 
microprocessor system (Fig. 
3) with most of the 72 
utilizing several of the seven 


possible addressing modes: 
Accumulator, implied, 
relative, direct, immediate, 
extended and indexed. 

e Accumulator — ìn 
accumulator addressing, 
either accumulator A or 
accumulator B must be 
specified. 


e [mplied — |n implied 
addressing the instruction 
code itself specifies the 
operand (stack pointer, 
index register, etc.). 

e Relative — Relative 
addressing is used for the 
branch instructions and 
indicates the value 
contained in the word of 
memory immediately 
following the instruction 
code added to the program 
counter +2 with the result 
then loaded back into the 
program counter. Positive 
data (bit 7 = 0) generates 
forward jumps up to 129 
words from the branch 
instruction while negative 
data (bit 7 = 1) generates 
backward jumps up to 125 


words from the branch 
instruction. 

ө Direct — |n direct 
addressing, the value 
contained in the word of 
memory immediately 


following instruction code is 
an actual memory address 
within the first 256 words 
of memory (000016 to 
OOFF) which contains the 
operand of the instruction. 
This mode typically saves 
one CPU cycle of execution 
when compared to extended 
addressing. 

e /mmediate — In 
immediate addressing, the 


value contained in the word, 
or in some cases two words 
of memory, immediately 
following the instruction 
code is the operand of the 
instruction, 

e Extended — In 
extended addressing, the 
two words of memory 
immediately following the 
instruction code contain the 
address of the memory 
location which contains the 
operand of the instruction. 


€ [ndexed — |n indexed 
addressing, the value 
contained in the word of 


memory, immediately 
following the instruction 
code, is temporarily added 
to the contents of the index 
register generating a new 
address where the operand 
of the instruction is located. 
The jump is positive only, 
going from 0 to 255 words 
and the actual contents of 
the index register are not 
changed. 

Also provided on the main 
processor board is an 
MC14411 baud rate generator 
which uses an external 
1.8432 MHz crystal and 
internal oscillator and divide 
chain to generate serial 
interface clocks for baud 
rates of 110, 150, 300, 600 
and 1200 baud. Also derived 
from this circuit is the 921.6 
kHz clock used by the 
MC6800 microprocessor 
clement. It is first, however, 
fed into a gating circuit 
generating two non 
overlapping, 5096 duty cycle, 
complementary clock signals 


$1 and ф2. 


Mother Board (MP-B) 


The Mother Board (coded 
MP-B) is a 9" x 14" double 
sided, plated-through hole 
circuit board onto which all 
of the various processor 
boards are plugged. Provisions 
have been made for one 
Microprocessor/System 
Board, up to four 4,096 word 
random access memory 
boards plus two unused slots. 
This allows the system to be 
expanded to 16,384 words of 


memory. For those 
demanding even more 
memory, the 50-line system 
information bus may be 
paralleled onto another 
mother board with separate 
power supply expanding the 
system to a maximum of 


32,768 words of random 
access memory. 
The Mother Board also 


provides the line buffering 
and address decoding for up 
to eight interface boards. 
Although one of the eight 
must be the serial terminal, 
control interface, the other 
seven may be any 
combination of parallel or 
serial interfaces the user may 
choose to have. For those 
demanding even more 
interfacing capability, the 
50-line system information 
bus may be paralleled onto 
another mother board with 
separate power supply 
expanding the  interfacing 
capability to one terminal, 
control interface plus any 
combination of up to 15 
serial or parallel interfaces. 
The following is a brief 
description of each of the 50 


lines on the system 
information bus: 
The AO — A15 lines 


carry address bits 0 through 
15 respectively, forming a 
16-bit address which is used 
to define either a memory 
location or interface 
address. 


The BUS AVAILABLE 
line goes high ac 
knowledging a processor 
halt, meaning the processor 
has stopped and that the 


system information bus is 
available for external 
control. 


The DO — D7 lines carry 
inverted data bits O through 
7 respectively, forming 8-bit 
data words which are 
exchanged between the 
various boards within the 
system. 


The GND line 
system’s common 
supply ground point. 


is the 
power 


Fig. 3. The 6800 microprocessor’s instruction set. This is a list of the 
mnemonics available. A more complete explanation of the basic 
operations of the processor is found in Motorola's programming manual 
for the 6800 which is part of the SWTPC documentation package. 


SBC 
SEC 
SEI 
STA 


STS 
STX 


TAB 
TAP 
TBA 
TST 
TSX 
TXS 


WAI 


ADD ACCUMULATORS 

ADD WITH CARRY 

ADD 

LOGICAL AND 

ARITHMETIC SHIFT LEFT 
ARITHMETIC SHIFT RIGHT 
BRANCH IF CARRY CLEAR 
BRANCH IF CARRY SET 
BRANCH IF EQUAL TO ZERO 
BRANCH IF GREATER OR EQUAL ZERO 
BRANCH IF GREATER THAN ZERO 
BRANCH IF HIGHER 

BIT TEST 

BRANCH IF LESS OR EQUAL 
BRANCH IF LOWER OR SAME 
BRANCH IF LESS THAN ZERO 
BRANCH IF MINUS 

BRANCH IF NOT EQUAL TO ZERO 
BRANCH IF PLUS 

BRANCH ALWAYS 

BRANCH TO SUBROUTINE 
BRANCH IF OVERFLOW CLEAR 
BRANCH IF OVERFLOW SET 
COMPARE ACCUMULATORS 
CLEAR CARRY 

CLEAR INTERRUPT MASK 
CLEAR 

CLEAR OVERFLOW 

COMPARE 

COMPLEMENT 

COMPARE INDEX REGISTER 
DECIMAL ADJUST 

DECREMENT 

DECREMENT STACK POINTER 
DECREMENT INDEX REGISTER 
EXCLUSIVE OR 

INCREMENT 

INCREMENT STACK POINTER 
INCREMENT INDEX REGISTER 
JUMP 

JUMP TO SUBROUTINE 

LOAD ACCUMULATOR 

LOAD STACK POINTER 

LOAD INDEX REGISTER 
LOGICAL SHIFT RIGHT 
NEGATE 

NO OPERATION 

INCLUSIVE OR ACCUMULATOR 
PUSH DATA 

PULL DATA 

ROTATE LEFT 

ROTATE RIGHT 

RETURN FROM INTERRUPT 
RETURN FROM SUBROUTINE 
SUBTRACT ACCUMULATORS 
SUBTRACT WITH CARRY 

SET CARRY 

SET INTERRUPT MASK 

SET OVERFLOW 

STORE ACCUMULATOR 

STORE STACK REGISTER 
STORE INDEX REGISTER 
SUBTRACT 

SOFTWARE INTERRUPT 
TRANSFER ACCUMULATORS 
TRANSFER ACCUMULATORS TO 
CONDITION CODE REG. 
TRANSFER ACCUMULATORS 
TRANSFER CONDITION CODE REG. 
TO ACCUMULATOR 

TEST 

TRANSFER STACK POINTER TO 
INDEX REGISTER 

TRANSFER INDEX REGISTER TO 
STACK POINTER 

WAIT FOR INTERRUPT 
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The normally high HALT 
line when brought low halts 
the processor and frees the 
system information bus for 
external control. 


The INDEX line is an 
unused one and is provided 
so the pin on each of the 
male connectors may be cut 
with the corresponding 
female connector pins 
plugged, preventing the 
circuit boards from being 
plugged on incorrrectly. 


The IRQ is the maskable, 
single level interrupt request 
line feeding the processor 
board. If not inhibited by 
software it will when 
momentarily given a TTL 
zero level signal, force the 
processor into a push-down 
stack store routine followed 
by a program jump to a user 
selected address stored in 
the operating system RAM. 


The M. RESET line, 
when momentarily 
grounded manually, 
indirectly resets the registers 
internal to the processor 
and interfaces, and loads the 
ROM stored mini-operating 
system. This line is normally 
grounded by depressing the 
RESET button on the 
system’s front panel. 


The NMI is 
non-maskable, 


the 
single level 


Once you've assembled 
and checked out the 
operation of your MP-68 
kit, the result will be a 
product which looks like 
this. Note the complete 
absence of most of the 
usual control panel 
functions you might 
expect. This is achieved by 
using a serial communica- 
tions device such as a 
Teletype or an RS-232C 
compatible terminal as the 
"front panel." 
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interrupt line feeding the 
processor board. When 
momentarily given a TTL 
zero level it forces the 
processor into a push-down 
stack store routine, 
followed by a program jump 
to a user selected address 
stored in the operating 
system RAM. The NMI is 
not maskable thus cannot 
be inhibited by the 
programmer through 
software. 


Q2 is one of the two 
complementary system 
clock outputs and is used to 
signal that valid data is on 
the data lines DO — D7 
when low. 


фт is the non-overlapping 
clock complement of (9o. 


The RESET line when 
low resets the registers 
internal to the processor 
and interfaces, and loads the 
ROM stored mini-operating 
system. This line is activated 
by one shot on the 
Microprocessor/System 
board when the system is 
first powered up or when M. 
RESET line is momentarily 
grounded. 


The R/W line establishes 
the direction of data flow 
on the eight data lines, DO 
— D7. It is high for a read 
from memory or interface 


and is low for a write to 
memory or interface. 


ММА is the valid 
memory address line which 
goes low to confirm that 
valid memory address data 
is being presented on the 16 
address lines, AO — A15. 


The UD1 and UD2 are 
user defined lines and have 
not been assigned a 
function. 


The —12 and +12 points 
are lines to which an 
isolated ground —12 @ 200 
mA and +12 @ 200 mA 
power supply should be 
connected. The voltages are 
necessary for generating the 
currents required by 20 mA 
current loop Teletype 
equipment on the serial 
interfaces. 


The 7 — 8 VDC UNREG 
point is the line to which a 
+7 to 8 volt dc @ 10 Amp 
unregulated power supply 
should be attached. This 
voltage is then regulated 
down to +5 V dc by 
independent regulators on 
the various boards within 
the system. 


The five 110b, 150b, 
300b, 600b, 1200b lines 
carry 1758.8, 2400, 4800, 
9600 and 19200 Hz clocks 
required by the serial 
interfaces for 110, 150, 300, 


600 and 1200 baud 
communication. 
Also attached to the 


50-line system information 
bus are the interface decode 
and driver circuits. A 
considerable cost savings is 
made here by providing the 
address decoding and 
information bus buffering for 
all of the interfaces right on 
the mother board instead of 
providing it on each of the 
interface boards individually. 
Since each of the parallel 
interfaces require four 
address locations and the 
serial two, four addresses are 
provided for each of the 
interface positions. They are 
assigned as shown in the 
memory map, Fig. 2. 
Interface position 1 (8004 — 
8007) is reserved for the 
terminal control interface. 
The signals carried on the 
interface information bus are 
almost identical to those on 
the system bus. UD3 and 
UD4 are here again User 
Defined data lines and RSO 
and RS1 are Register select 
lines which are identical to 
address lines AQ and Al 
respectively. Power for the 
address decode and buffer 
circuits on the mother board 
is provided by a separate on 
board regulator with a 
current consumption of 
typically 0.4 Amp. в 


(More SWTPC 6800 data is 
coming in BYTE.) 
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COMPUTER EXPERIMENTER SUPPLIES 


FACTORY FRESH—PRIME QUALITY 
PERFORMANCE GUARANTEED 


MICROPROCESSORS AND MEMORY 


Commercial Grade—up to 35°C. 


These units are factory 
fresh, full spec devices. 


COMPUTER GRADE REGULATED POWER SUPPLIES 
All units are short-circuit proof, fold back current пите and with 


over-voltage crowbar protection. 


MD-5-1 
+5 Volt at 1 Amp 
$24.50 


MD-15 

+15 Volt at 200MA 
Dual Tracking 
$30.00 


MICRO COMPUTER SUPPLY 
COMBINATIONS 


For the 8008 
MD-08—+5 volt at 6 amp, -12, -9 at 200 
For the 8080 

MD-80—+5 voltat6 amp, +12vat200ma... 
For the Fairchild F-8 

MD-8—+5 voltat6amp,+12vat200ma .. 
For the M6800 

MD-5—+5 volt at6amp 


$75.00 
. $65.00 


All units are short circuit proof, fold-back current 
limited and with over voltage crowbar protection. 


All Prices Subject to Change Without Notice 
Minimum Order $10.00 
Add $1.00 to Cover Postage and Handling 
Send Check or Money Order (No C.O.D.) To: 
N. J. Residents Add 5% Sales Tax 


MD-5-3 
+5 Volt at 3 Amp 
$34.50 


+5 Volt at 6 Amp 
$44.50 


TTL INTEGRATED CIRCUITS 


All devices are factory fresh, full spec units. 


BOX 413, EDISON, NJ 08817 e (201) 549-2699 


First Person Report: 


by 

John Zarrella 

90-9 Wakelee Rd. 
Waterbury CT 06705 


| decided 1 would have 
to opt for a kit...this 
would enable me to get 
on line quickly. 
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Assembling an 
Altair 8800 


My adventure with 
microprocessors began rather 
late in the hobby game, at the 
end of 1974. |t was about 
this time, or so it seemed to 
me, that micros became the 
topic of conversation in 
anything related to 
computers and automation. 
With the IMP-16, the 8080, 
8008, 4004, etc., it became 
clear that this was what the 
computer market was waiting 
for. However, it was the 
article on the MITS Altair in 
the January 1975 issue of 
Popular | Electronics which 
finally did it. Although 
inaccurate and vague, it 


certainly decided me — | was 
definitely going to own a 
micro. The next few months 
saw hurried mailings of 
information requests to any 
company which produced a 
product even remotely 
connected with a 
microprocessor. | 
immediately got out my 
checkbook, and mailed all my 
hard earned dollars to every 


newsletter that was 
published, in my frantic 
search for the "right" 
processor. 

The results were both 


rewarding and disappointing. 
| found that there were some 


Fig. 1. The schematic diagram of power supply circuitry, showing 


additional protection diodes. 
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fantastic processors, but since 
my hardware background is 
not all that hot, | decided 
that | would have to opt fora 
kit with one of the most 
powerful micros | could find. 
| figured that this would 
enable me to get on line 
quickly, learn enough 
hardware to keep up with the 
state-of-the-art, and permit 
me to evaluate new micros as 
they came out, so | could 
build my “dream machine" 
when the right parts became 
available. 

| decided to build the 
Altair 8800. Although the 
instruction set looked rather 
impressive, what convinced 
me was Seeing a process 
control system which used 
the 8080; | was truly 
impressed with its capability. 


The Order 


After calling in my order 
to MITS, | waited nearly 
seven weeks for delivery. 
MITS did make it within the 
advertised 60-day delivery 
time. All was not roses for 
those seven weeks, however; 
it seems that either MITS or 
BankAmericard got their 
signals crossed and couldn't 
get a credit authorization 
(they both eventually 


declined to accept 
responsibility). You can 
imagine what it was like 


getting a call during dinner, 
explaining that my unit was 


ready to ship, but 
unfortunately Luckily 
they agreed to ship it COD, 
and [ quickly ran down to my 
bank to get a certified check. 
Every morning | left my wife 
with the admonition not to 
miss the delivery, and every 
day at lunch | called to 
determine whether or not my 
“computer” had arrived. (Did 
you ever, try to ask your 
insurance agent whether you 
needed extra renter’s 
insurance 
computer at home??!! What 
for?") 
Assembly 

Within a week of that call, 
| had the Altair in my hot 


little hands. "Are those little 
plastic parts all you get for 


$500.00?"', my wife 
exclaimed, peering over my 
shoulder, Undaunted, 1 


shooed her out and locked 
myself in the back room all 
weekend soldering PC boards. 
It took three weekends to 
complete the assembly (was it 
my fault | came down with 
pneumonia in the middle?). 

Ah yes, assembly. In 
general, | found that the 
MITS assembly instructions 
were well written. However, 
their additions were 
sometimes in the manuals in 
the wrong place (e.g, page 
68A after 69). In at least one 
case (front panel control 
board) | had already 
tightened the panel in place 
(bolts on numerous switches), 
when І read that the nut on 
the little screw holding the 
voltage regulator to the board 
(accessible only with the 
panel out) had to be removed 
to add a grounding strap. 
Therefore it pays to check 
the manual pages carefully, 
and look two or three pages 
ahead to see if there are any 
little tricks sneaking up on 
you. 

As for the parts, only one 
resistor was missing; however, 
out of all the screws and bolts 
supplied with the kit, | could 
never find the right one to fit. 
Maybe it was my own 
stupidity, but it seemed that 


"You keep a. 


Of all the assembly, the worst (and easiest to mess up) 
part was correctly connecting the 60 bus wires between 


the last bolt of any given size 
was always supposed to be 
used in at least 10 more 
places. | found that it pays to 
have a good assortment of 
screws and bolts (number 6, 
various lengths 1⁄4” to 34") to 


permit frustrationless 
assembly. 
All soldering and 


component placement was 
easily accomplished — 
positions were clearly marked 
on the boards and in the 
manual. This is high praise 
since | hadn’t built many kits 
before; and of these, none 
were this large. Of all the 
assembly, the worst (and 
easiest to mess up) part was 
correctly connecting the 60 
bus wires between the 
display/control board and the 
chassis motherboard. | used 
an Ohmmeter to assure that 
each connection was correct 
and that there were no solder 
bridges to the other bus lines. 
There’s got to be a better 
way. 1 hear Processor 
Technology, Inc., is currently 
marketing a 16-slot 
motherboard (on the Altair 
you have to jumper four of 
the four slot boards together, 
only one of which comes 
with the kit), and an 
improved connector for the 
display/control board. These 
will definitely be my first 
additions. 


| made only one 
modification to the circuit 
during assembly. That 


modification was to add three 
protection zeners to the CPU 
board. Fig. 1 shows the 
electrical connections for this 
change. These were inserted 
to protect the 8080 chip (still 
pretty expensive in singles) 
from power supply failure. 
These zeners should ground 
out overvoltages at currents 
up to 100 Amps. ICTESs 


were used for the +5 V and 
—5 V lines to the 8080 and a 
1.5KE15 for the *12 V. The 
zeners on the CPU board are 
illustrated in Fig. 2. 

| also added sockets for 
the 8101 RAMs, cleaned all 
boards with trichloroethylene 


solvent, and inspected the 
finished boards with a 
magnifying glass. | would 


highly recommend these 
procedures as they helped me 
find more than one solder 
splash and cold solder joint. 


The Big Test 


On the fourth weekend | 
got up the courage to mount 
the 8080 and 8101s. Then 
came turning on the power 
and checking voltages. 
Everything looked good, with 
very little ripple from the 


the display/control board and the chassis motherboard. 


Did you ever try to ask 
your insurance agent 
whether you need extra 
renter's insurance for a 
computer? 


Fig. 2. Detail of the additional protective diodes 
mounted on the Altair CPU board. 


Additional zener 
diodes for overvoltage 


protection. 


8080 Central Processor 
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Fig. 3. Adding a parallel capacitance of .0047 uF to C8 of the Altair CPU board schematic lengthens the data 


out enable line time so that memory write does not extend longer than the data out time. 


EXM NXT 
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С 


ПЕР МХТ 


on-card voltage regulators. 
Finally the big test: Run a 
program. This is where the 
only problem finally showed 
up. | stopped and reset the 
CPU, set the switches for my 
spectacular program (JMP 0) 
and would you believe it, 
"deposit" wouldn't work. An 
hour later ! had determined 
that all other panel switches 
worked correctly (including 
deposit next), and that the 
deposit switch itself was in 
good order. In order to 
initially get around the 
problem | had to examine 
location 177777 (all address 
bits 1), then use deposit next 
to get to location O. 


A study of the schematics 
showed that deposit and 
deposit next use the same 
circuitry, except that deposit 
next first does an examine 
next. You can verify this 
visually by loading all ones 
into the first 10 locations of 
memory. Then, if you use 
deposit next to change all the 
locations to zero, by carefully 
watching the data LEDs, you 
will notice that they all-flash 
on as the switch is activated 
(examine next) and 
immediately go off again as 
the deposit is performed. 

| concluded that the 
problem had to be in the 
timing, since the circuits were 
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otherwise identical. Sure 
enough, when I looked at the 
signals on a scope, lo and 
behold, when a deposit was 
performed, the memory write 
line was enabled for 
approximately 20 ns more 
than the data out line. There 
are two oneshots in the 
deposit circuit; the^ first 
enables the memory write 
line, and the second enables 


TO 


MWRITE 
LINE 


TO DATA 
OUT ENABLE 
(SWITCHES 
SAO- SAT) 


GND 


+5V 
RIO 
MODIFICATION 
C=.0047 nF 
the data out line. The 


memory write problem was 
cured by increasing the 
capacitance on the second 
deposit oneshot. An increase 
of .0047 uF (which increases 
the data out enable time by 
at least 30 ns) proved 
sufficient. This was obtained 
by adding the .0047 uF 
capacitor as shown in Fig. 3. 
When building the Altair, this 


means that C8 (front panel 
control board) should be 
approximately .0147 uF; if 
the board is already 
assembled into the case, a 
.0047 uF capacitor can easily 
be soldered onto the back of 
the board without removing 
any components from the 
case. (Be sure to unplug the 
computer before making the 
change, however. Fig. 4 
shows placement of the new 
capacitor and the change to 
the Altair schematic diagram. 


| feel that the kit is 
reasonably well made and a 
good buy — at least at the 
current 8080 single lot prices, 
though the add-on options 
may cost somewhat more 
than elsewhere. 


My plans for my unit 
currently involve addition of 
vectored interrupts (a 9318 
or 74148 8-bit to 3-bit 
priority decoder is about all 
that's needed to translate the 
eight vectored interrupt lines 
on the bus into an RST 
instruction), a real-time 
clock, monitor clock and 
some type of I/O (teletype, 
CRT, еїс.). m 


Fig. 4. The additional .0047 uF capacitor is mounted on the rear of the control panel board. 


Solder the 
additional capacitor 
to the rear of the 
control panel board. 


Modify this section 
of your schematic. 
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At last! High quality, laboratory-grade test E ae 
for the professional and hobbyist . . . at prices everyone can afford! 


CIRCUIT DESIGNER 
Now you can build/test electronic circuits 
WITHOUT SOLDER ... using solid #22 AWG 
wire to interconnect discrete components 7 
resistors, transistors, linear/digital ICs in TO5 Add $2.50 
or DIP packages (8- -40 pins), and more. Plus, shipping/handling 
you get 5-15VDC up to 600ma (9 watts) of 
variable regulated power, with a built-in 0-15V 
voltmeter to monitor internal power and/or 
extemal circuits. Now, that's design flexibility! 
And look at the low, low price! 


d R/C BRIDGE 


Have you been bugged by color codes or unreadable 
component markings? Forget it! DM-3, the low cost 
R/C Bridge, measures true component values . . . in 
seconds ... to better than 5%. And, it's all done with 
only 2 operating controis and a unique solid-state null 
detector, to zero-in on exact component selection... 
instantly! Completely wired, calibrated and tested, 
DM-3 includes an extensive instruction/applications 
manual, and operational theory too. 


49% 


Add $2.50 
shipping/handling 


SPECIFICATIONS 
Power Supply: Output: 5-15V (9 


600ma. Ripple and 
Noise: less than 20mv (9 full load. Load/Line 
regulation: «196. Meter: 0-15V DC. Connectors: 1 
QT-598, 2 QT-59B, 2 power supply 5-way binding 
posts, 2 meter 5-way binding posts. Wght: З Ibs. 
Power Needed: 117V, AC @ 60 Hz 12W.* 

Patent £235,554. 


Each measures 6.75'' x 7.5’'W х 3.25'' H.; completely assembled, ready to start 


FUNCTION GENERATOR 
Troubleshooting? Design Testing? DM-2 gives you all 
the signal source capacity you need... at a very 
modest price. This 3-wave form Function Generator 
has: short-proof output, variable signal amplitude and 
constant output impedance. Completely wired, tested, 
calibrated, ready to test audio amplifiers, op-amp and 
educational lab designs ... as well as complex 
industrial lab projects. Complete with easy-to-read 
instructions/operations manual, application notes, 
operation theory and more, DM-2 works hand-in-hand 
with DM-1 for total versatility. 


SPECIFICATIONS 

Frequency Range: 1Hz-100KHz (5 ranges: 1-10Hz, 
10-100Hz, 100-1000Hz, 1-10KHz, 10-100KH2). Dial 
Accuracy: Calibrated @ 10Hz, 100Hz, 1KHz, 10KHz, 
freq. accurate to 5% of dial setting. Wave Forms: Sine 
<2% THD over freq. range. Triangle wave linearity, 
<1% over range. Square wave rise/fall <0.5 
microseconds — 6000-20рі termination. Output 
Amplitude: (all wave forms) variable-0.1V-10V peak to 
peak into open circuit. Output Impedance: 
6000-constant over ampl./freq. ranges. Wght.: 2 Ibs. 
Power Needed: 117V, AC @ 60Hz 5W.* 


shipping/handling 


SPECIFICATIONS 

Resistance Range: 100-100 теп. (6 Ranges: 
10-1000, 100-1000, 1K-10KQ, 100K-1 megQ, 1 
megQ-10 megQ) Capacitance Range: 10pFd-tmFd- 
(5 Ranges: 10-100 pFd, 100-1000pFd, .001-.01 

mFd, .01mFd-.1mFd, .1- 1.mFd.) Null Detector: 2 
hi-intensity LEDs-hi/lo markings. Accuracy: <5% of 
null dial, range switch setting. Wght. 2 Ibs. 

Power Needed: 117V, AC @ 60Hz 3W.* 


5495 


testing at once. Order your DESIGN MATES today! 
*220V @ 50Hz available at slightly higher cost. 


All DESIGN MATES are made in USA; available off-the-shelf from your 
local distributor. Direct purchases from CSC can be charged on Bank 
Americard, Master Charge, American Express. Plus, you get a FREE 
English/Metric Conversion Slide Rule with each order. Foreign orders 
please add 10% for shipping/handling. Prices are subject to change. 


LC 
CONTINENTAL SPECIALTIES CORPORATION 


44 Kendall Street, Box 1942, New Haven, CT 06509 e 203/624-3103 
West Coast Office: Box 7809, San Francisco, CA 94119 e 415/421-8872 
Canada: Len Finkler Ltd., Ontario 


© Copyright Continental Specialties Corporation 1975 


Can YOUR 


Com 


puter 


ell lime? 


Loops are the basic 
time delay elements. 
Then there are loops 


within loops, loops 
within loops within 
loops and so on ad 
infinitum. 


Can your computer tell 
time? O.K. Now take away 
the LSI clock chip, pocket 
watch, grandfather clock, or 
whatever else you managed to 
interface together. Can your 
computer still tell time? You 
bet it can! 

It is a readily accepted fact 
that almost any type of 
hardware logic device can be 
imitated or simulated by 
computer software. That can 
also include timing devices if 
you wish. 

We will examine a few 
methods and considerations 
for software timing, then 
apply what we've learned in 
making a novel "software 
only" clock which will keep 
time as well as any 
conventional clock. 

The most efficient method 
(efficient referring to 
memory space used) to 
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produce a time delay is the 
use of a loop. This loop is 
basically very simple, as 
shown by Fig. 1. By including 
NOPs or other non-functional 
time wasters in the loop, the 
loop can be significantly 
stretched. 

An 8008 is being used in 
the examples in this article, 
but the principles hold for 
any computer. Only the 
numerical values will change. 

The loop represented by 
Fig. 1 for an 8008 would be a 
simple three instructions (six 
bytes) long. 


LBI 

"yn ] LOAD DELAY 
DCB DECREMENT "x" 
JFZ 

L JUMP BACK 

H UNLESS X = 0 


The value of “x” loaded 
into the B register will be the 
main factor in varying the 
time delay provided by this 
loop. Calculating the exact 


time period is done by 
tabulation of instruction 
execution times. These 


examples will be based on the 
8008 instruction execution 
times with the clock running 
at exactly 500 kHz. 


by 

James Hogenson 
Box 295 

Halstad MN 56548 


OPTIONAL 
"NOP" 
TIME 


Fig. 1. The idea of a timing loop, 
or how to make a CPU waste time 


productively. 


To calculate the time for 
this loop, assume the value of 
“x”? to be 1 so no part of the 
loop is repeated. Add up the 
number of microseconds 
required by each instruction. 


LBI = 32 US 
DCB = 20 US 
JFZ = 36 US 

88 US 


Now go back to determine 
how many microseconds each 
repetition of the loop will 
produce. The LBI instruction 
is not repeated. Do not count 
any unrepeated instructions 
in this second tabulation. 


DCB = 20 US 
JFZ = 44 US 
64 US 

Note the different 


execution times for the JFZ 
instruction. For the 8008, the 
execution time of conditional 


instructions depends upon 
the condition. If the 
condition results in a true 


branch, the instruction takes 
the longer of the two 
execution times. The false 
branch is the shorter time. 
The time formula for this 
loop is 
64X + 24 =N 


FROM MAIN 
PROGRAM 


SET VALUE 
OF 
REGISTER 


DECREMENT 
REGISTER 


RETURN 
TO MAIN 
PROGRAM 


"X" being the value loaded 
into B and ''n" being the 
total execution time іп 
microseconds. The unreduced 
formula is 

(X - 1364 + 88 =N 
Since 64 us are added for 
each repetition, we must 
multiply 64 by one less than 
the value of “х.” 

255 is the largest possible 
value of “x” since we are 
limited to an 8-bit word. 
Therefore, the maximum 
time delay that сап be 
provided by this loop is 
16344 us. This loop can be 
stretched by placing a NOP 
instruction (op code 300) 
before the DCB, and 
re-routing the jump. 


LBI SET VALUE OF "x" 
toe 

x 

МОР ABSORB EXTRA 20 US 
DCB  DECREMENT "x" 
JFZ JUMP BACK TO NOP 
L UNLESS X = 0 
H 


If desired, more than one 
NOP may be inserted. Each 
NOP will add another 20x 
microsedonds. The maximum 
time with one NOP is 21444 
us, the NOP adding 5100 us. 

If a timing loop is to be 
used a number of times at 


various points in a program, it 
may be desirable to rewrite 
the loop as a called 
subroutine. The basic 
flowchart remains unchanged; 
only the method of 
implementing it changes. 


(MAIN 
PROGRAM) 
CAL CALL 
L TIME 
H LOOP 
(TIME 
LOOP) 
LBI SET VALUE OF "x" 
"y" 
DCB DECREMENT "x" 
RTZ RETURN IF "X" - 
JMP 
L JUMP BACK TO DCB 


Tabulation will show that 
the basic loop is good for 116 
us with each repetition 
adding 76 us. The reduced 
formula is 

76X + 40 =N 

This loop is a little more 
complex. Although the CAL 
instruction which calls the 
loop is not a part of the loop 
itself, the execution time of 
the CAL instruction is a part 
of the time period produced. 
We, therefore, must add 44 us 
for the CAL. 

As done before, we assume 
the value of "x" to be 1 for 
the first tabulation. The RTZ 
will be a true branch, so we 
stop adding there. An RTZ 
true branch will take 20 us, 
while an RTZ false branch 
will take 12 us. 

Each repetition will add 
12 us for the RTZ, 44 us for 
the JMP, and 20 us for the 
DCB instruction. The 
unreduced formula is 

(X - 1)76 + 116 =N 

NOPs placed before the 
DCB instruction will have the 
same effect as in the first 
loop, an additional 20x us per 
NOP. 

The maximum time period 
produced by this second loop 
with one NOP is 24520 us. 
The minimum time period 
without any NOPs is 116 us. 
Anything under 116 us can 


be more efficiently 
implemented with straight 
NOPs than with a loop, 


should such a need arise. 


If a time period much 
longer than 24000 us is 
needed, modify the time loop 
to make a double loop as 
shown in Fig. 2. Make an 
identical loop, but rather 
than using a NOP for more 
time, insert an entire loop. 


CAL 
L 
H 


(TIME LOOP) 


(TIME LOOP) 


LCI SET VALUE OF "Үү" 
ny" 
A NOP 
LBI SET VALUE OF "x" 
ux" x 
B NOP 
DCB DECREMENT "x" 
JFZ 
L JUMP BACK TO DCB 
H IF "x" x 0 
DCC DECREMENT " 
RTZ RETURN IF "y" о 
ЈМР 
L JUMP TO LBI 
H 
Time calculations for 
multiple loops become 


somewhat more complex, but 
again the same principle is 
used. 

The inside loop used here 
is the same loop first 
calculated at the beginning of 
this article. When calculating 
the main loop, the inside loop 
is treated as one combined 
unit of value. The tabulation 
will look like this: 


MAIN LOOP: 


CAL = 44 US 

LCI = 32 US 

INSIDE 

LOOP = (64X + 24) US 

pcc = 20 US 

RTZ = 20 US 

(64X + 140) US 

EACH REPETITION OR 
TRUE BRANCH WILL ADD: 
RTZ = 12 US 
JMP = 44 US 
INSIDE 
LOOP = (64X + 24) US 
DCC = 20 US 


(64X + 100) US 


The formula, unreduced, 
would be 


64X + 140 + 
(Y-1)(64X + 100) = М 


Reducing the formula 


gives us 
64XY + 100X + 40 =N 


SET VALUE 
OF Y 
SET VALUE 
OF X 


RETURN 


Fig. 2. Getting fancy. By nesting one timing loop 
within an outer loop, much longer delays can be 


obtained. Two parameters "x" and "y" are re- 


quired to completely specify this loop. In a 16-bit 
machine, of course, the same result (here intended 
for an 8-bit 8008) can be obtained without nested 
loops since the 16-bitter can count much higher. 


would place a CAL 
instruction between point A 
and point B which would call 
the time loop. The shorter 
loop will be sufficient for this 
application, so the equation 
will now be 


The maximum time delay 
provided by this loop would 
be 4187140 us. A NOP 
inserted at location "a" will 
add 20y us. A NOP at “b” 
will add 20xy us. The use of 
both NOPs will boost our 
maximum time to 5492740 
us, or over 5 seconds. 

The purpose of developing 
formulas is to determine the 
values of the registers needed 
to obtain a specified time 
period. For purposes of 
illustrating an example, let us 
assume we want exactly 5000 
us to pass between point A 
and point B of a program. We 


76X + 40 = 5000 


Working the equation will 
give a value of 65.23615 ... 
for "x." A fractional value 
will not fit in any single 
register of the CPU. To find 
out what to do now, multiply 
65 by 76, add 40, and 
subtract the result from 
5000. We find the difference 
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is 20 us. This is very simple to 
take care of. Insert a NOP 
instruction at any point in 
the routine where it will not 
be repeated. Before the LBI 
instruction would do fine. 
Now, with 65 (decimal 
notation) loaded into the B 
register, exactly 5000 us will 
pass between points A and B 
of our main program. 

Finding an exact time 
period using the longer loop 
involves a certain amount of 
trial and error. To find an 
approximate value of “х” 
(using no NOPs) use this 
formula: 
=) - 

64Y 

Assign an arbitrary value 
to “у,” replace “n” with the 
required time period. 

Now, assume a time period 
of exactly 505904 us is 
needed. (This time period will 
be used later.) There is one 
stipulation in this case which 
will be explained in greater 
detail later. The value of “x” 
must be 255. Solving the 
formula equation for “у” 


(64)(255)Y + 
100Y + 40 = 505904 


gives “у” a value of 30.8078. 
30 must be used for “y.” The 
total time of the loop is then 
492640 us, 13264 us short of 
the required time. In most 
cases, you would re-assign 


values and try again, but in 
this case, the value of “x” 
cannot be changed. The 
alternative is to use the 
shorter loop to clean up the 
leftovers. After calling one 
loop, call the other loop. 
Then go on with the main 
program. Solving the short 
loop equation comes out at a 
nice even 174. 


76X * 40 - 13264 
What looked like а real 
oddball turned out to be 
perfect! 

The formulas and all such 
may seem like a lot of 
monkey business just to 
waste time. Speed jis the 


purpose of computers, but 
there are times when they 
must be slowed down. 

The primary application of 
time loops is in I/O interface. 
If a computer is to monitor a 
data input which is to be read 
once every 10 ms, there are 
two alternatives for timing. 
The hardware of the device 
being monitored may include 
a timing device and a flag to 
indicate when the device is 
ready. The computer enters a 
loop which monitors the flag 
until the device is ready, then 
reads the data. The other 
alternative is to use the 
software time loop, and omit 
the extra hardware. 


An interesting application 
along this line is a completely 
software  ''fabricated"' 
keyboard debounce system. 
This method will not work in 
an interrupt type of input 
system, but for many small 
scale systems, this method is 
ideal. 

Rather than connecting 
the Áeypressed line of the 
keyboard to some debounce, 
timer and latch circuitry, 
connect it to the eighth bit of 
the parallel data input on the 
computer. The loop used will 
test the eighth bit for the 
keypressed state. When a 
keypressed is sensed, a time 
loop of 16344 us is executed, 
then the data input is 
accepted. The loop then 
branches back to the main 
program to take care of the 
new data. When the program 
comes back to the input loop, 
the keypressed line is first 
tested to be sure no keys are 
being pressed. After all keys 
have been released, the loop 
will wait for the next 
heypressed state. This 
procedure will prevent more 
than one data entry from 
each keystroke. 

When | first tried this 
keyboard debounce method 
over five months ago, | was so 
pleased with it that l'm still 


Fig. 3. Software can be used to debounce a keyboard — simply loop 
around for a long enough time to ensure that keys have stabilized. The 
loop is started as soon as the "any key pressed" (keypressed) line 
indicates any non-null bit pattern. 


07/115 - 101 IN 
116 = 002 RLC TEST INPUT FOR KEYPRESSED, 
117 = 100 JFC WAIT UNTIL CONDITION IS 
120 = 115 L SATISFIED 
121 = 007 4H 
122 = 101 IN 
123 = 002 RLC TEST INPUT FOR KEYPRESSED, 
124 = 140 JTC WAIT UNTIL CONDITION IS 
125 = 122 L SATISFIED 
126 = 007 H 
127 = 026 LCI 
130 = 377 "255" EXECUTE 
131 = 021 DCC TIME 
132 = 110 JFZ DELAY 
133 = 131 L 
134 = 007 H 
135 = 101 IN ACCEPT INPUT OF DATA 
136 = 104 JMP 
137 = L JUMP TO MAIN PROGRAM 
140 =H H (MAY BE REPLACED WITH A 

RETURN INSTRUCTION.) 
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INCREMENT 
TIME 
COUNT 


INITIATE 
TIME 
CYCLE 


Fig. 4. The digital clock program 
looks simple at this level: Incre- 
ment the time count, update the 
display, then initiate a time cycle 
such that the entire loop takes 
exactly one second! 


using the method for all data 
entry to my microcomputer. 
Not once has it missed some 
data, or given me false or 
duplicated data. And it was 
so easy to implement! 

Time loops may also be 
used in output applications. | 
have an SWTPC TV 
typewriter, but | am not 
using the special computer 
interface board. | found that 
a simple time loop does the 


job well enough and fast 
enough. 
Since we've done our 


homework, now we can play. 
An interesting and novel 
application of time loops is a 
completely software 
"fabricated" clock. The clock 
program presented here will 
have three major functions 
(see Fig. 4). 

The clock will display 
hours, minutes and seconds. 
The "increment time count" 
segment of the program is 
responsible for computing the 
next time reading in 
sequence. It must consist of 
more than a straight counting 
sequence since time is not 
expressed in straight decimal 
format. 


The ‘‘update display” 
segment is responsible for 
producing the newly 


computed time at an output 
device. 

After the first two 
segments have been executed, 


Fig. 5. Ah, but the simplicity of Fig. 4 — as this figure reveals — hides a lot of low level detail. Here is the flow chart of the clock's operations. 
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8008 Timing Quick Reference Guide 


US. INSTRUCTION 
20 INCREMENT INDEX REGISTER 
20 DECREMENT INDEX REGISTER 
20 ROTATE ACCUMULATOR 
12/20 CONDITIONAL RETURN* 
36/44 CONDITIONAL JUMP* 
36/44 CONDITIONAL CALL* 
20 UNCONDITIONAL RETURN 
44 UNCONDITIONAL JUMP 
44 UNCONDITIONAL CALL 
20 RESTART 
32 LOAD DATA IMMEDIATE 
(INTO INDEX REGISTER) 
36 LOAD DATA IMMEDIATE 
(INTO MEMORY REGISTER) 
32 ALU IMMEDIATE 
20 ALU REGISTER 
32 ALU MEMDRY REGISTER 
24 QUTPUT 
32 INPUT 
20 LOAD DATA - REGISTER(OP CODE 3--) 
32 LOAD DATA - MEM. & REG. (OP CODE 3-7 OR 37-) 


Here is a quick reference table for execution times of all instructions 
in the 8008 repertoire. Such a reference table can be easily made for 
any CPU. Simply multiply the number of machine states required 
for the execution of each type of instruction by the time required 
per machine state. AT 500 kHz, the 8008 takes four us per machine 
state. An unconditional jump instruction requires 11 states in the 
8008 , therefore 44 us. Do not confuse machine states with machine 
cycles. The same jump instruction requires three machine cycles. 


*Conditional instructions: Execution time depends upon condition. 
If condition causes true branch, the execution time is longer. If the 
condition causes a false branch (if condition is not satisfied), the 


execution time is shorter. 


the ''time cycle" segment 
makes up the difference so 
that the entire program takes 
exactly one second per pass. 
Writing a clock program isn't 
hard, but making it take 
exactly one second per pass 
definitely adds to the 
challenge. The major 
consideration is that branches 
from conditional instructions 
must be balanced in such a 
way that the program will 
take exactly the same 
execution time regardless of 


When time balancing a 
segment of a program, it is 
best to work from the 
bottom and go up. The time 
adjustment in part A of the 
flowchart must compensate 
for parts B, C, D and E, so 
before that time period can 
be calculated, the execution 
time of the other parts must 
be calculated. 


Some of the time 
adjustments in part E do not 
use a time loop. The short 
time adjustments there (in 


the combination of part E) are more conveniently 
conditions and branches. implemented with a 
That's where all the time combination of other time 
loops come in, and that’s 


where lots of fun comes in! 

The program can best be 
described in the form of a 
flowchart, Fig. 5. The 
program listing in Fig. 6 is 
divided according to the 
flowchart divisions shown by 
dashed lines. The op codes 
are for 8008 systems. The 
mnemonics and op codes can 
be easily translated into 8080 
format. However, all timing 
considerations must be 
recalculated for use with 
anything other than an 8008 
running at exactly 500 kHz. 
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consuming instructions which 
will not change the function 
of the program. 


To determine the time 
adjustment needed in one 
branch, tabulate the total 
execution time of the longer 
branch. Add or subtract 8 us 
(depending upon which 
branch is the true branch) to 
compensate for the difference 
in conditional jump 
instructions. 


The same time loop will be 
used several times, yet the 
time periods will vary. This 


can be accommodated when 
using the short loop by 
placing the LBI instruction 
and loading the value of “х” 
before the loop is called. The 
location of the LBI 
instruction will have no effect 
on the overall time period 
produced. 

Occasionally a time loop 
will not come out evenly. For 
example, another 12 us may 
be needed. This will not be 
accommodated in the loop, 
so the only alternative is to 
use a NOP instruction. But 
the only instruction which 
will absorb just 12 us is an 
unsatisfied conditional return 
instruction. Using such an 
instruction could result in 
trouble if used alone. 
However, if an AND 
instruction can be used 
without affecting the 
program functions, the AND 
instruction will insure that 
the conditional return (RTC) 
wil! not be satisfied. To keep 
the program in balance when 
balancing the time, insert a 
NOP in the opposite branch 
to offset the AND 
instruction, and the net 
difference will be 12 us. 

Flowchart parts F and G 
need not be included in the 
time balancing considerations 
of A, B, C, D and E. The 
program returns to a common 
point before executing parts 
F and G, so those parts are 
not offsetting anything. 

The output loop as given 
in the listing will provide an 
ASCII output for a TV 
typewriter. A sufficient time 
loop is provided between 
each individual output 
operation. The output loop 
may be easily modified for 
use with other devices. For 
use with Teletype, a line feed 
command must be added to 
the output characters. (Only 
a carriage return is used with 
a TVT.) For use with an LED 
display, deleting the ORI 
instruction at location 
04/257 will leave a straight 
binary (also BCD equivalent, 
since vales do not exceed 9) 
output. Keep in mind, 


however, that modifying any 
part of the program will also 
require modifying the timing 
elements involved. 

The execution time of the 
complete "increment time 
count" segment plus the 
"update display” segment 
totals 494096 us. Subtract 
that time from one second to 
find the time required of the 
timing cycle. The required 
time is 505904 us. The values 
for this loop have already 
been worked out in a 
previous example. 

The reason the value of 
“x” cannot be conveniently 
changed in the long loop in 
this case is that the loop is 
called and used from two 
locations in the program. The 
value of “х” cannot be 
changed for one application 
without affecting the other. 
If the loop were modified to 
load B from another register 
which remained constant, 
both values would become 
variables which could be 
easily assigned values from 
any point in the program. 
This would also include 
recalculating the time 
formula of the loop. 

Your clock should now be 
ready to run. (Oh, by the 
way, there is one little 
drawback: Your computer 
can't be used for anything 
else while it's keeping time, 
unless, of course, you really 
want to go to extremes with 
the calculating! This program 
is strictly a novelty!) When 
you are ready to start your 
clock, load the correct time 
plus a couple of minutes into 
memory locations 04/000 
through 04/005. When the 
loaded time comes, start the 
computer. Jump into the 
program at 04/006. 

The time kept by the 
computer will only be as 
accurate as the frequency of 
the clock driving the CPU. 
The oscillator must be set at 
exactly 500 kHz. Although 
this is difficult to do, any 
percentage of error in fre- 
quency will be directly 
reflected by the time kept. m 


Fig. 6. And finally, the lowest level of detail of all: A “pseudo 
assembly" listing of the program for the digital clock as implemented 
for an 8008 computer. Of course, those readers who have an 8080, a 
6501, a 6800 or PACE will have to do a little bit of thinking to adapt 


Fig. 4 and Fig. 5 to the alternative microcomputer CPU designs. 


THOUR го саи 39 
es DL 
60679002 
мІМ: 004/003 
ТЕС: 0546004 
SEC 19447005 
START: 0047006 
0047007 

(a) 0047010 
0047011 
004701? 
0047013 
G0«7014 
0047015 
0047016 
004/017 
09067020 
0057521 
voasa 
harte 
0047024 
0047025 
004/026 
vgarte?7 
NGALAN 
0047031 
u0«z03? 
004/013 
A042 034 
Uae 35 
D0045936 
LP AUN 
^D эш, 
QG4/041 
0042604, 
02057043 
UGS ae 


СТЕР" 


0047045 
004/7046 
0047047 
004/050 
005/051 
0047052 
9047053 
004/054 
0047055 
004/056 
00457057 
004/060 
004/061 
0047062 
GOMIN: 0047063 
0047064 
0047065 
0047066 
0047267 
0047270 


004/071 

004/072 
0047073 
0047074 
0047075 
004/076 
0047077 
0047100 
0047101 
0047102 
0047103 
0047104 
004/105 
0047106 
0047107 
0047110 
O047/11I 
0067112 
0047113 
004/114 


GTENM: 


0047120 
004/121 
004/122 
004/123 
0047124 
0047125 
004/126 
004/127 
004/130 
004/131 
0047132 
004/133 
004/134 
004/135 
004/136 
GOHOUR ı 0047 137 
004/140 
0047141 
02347 142 
004/143 
004/144 
004/145 
Q04/ 146 
70047147 
004/150 
004/151 
0047152 


ххх 
ххх 
ххх 
ххх 
ххх 
ххх 


056 
004 
066 
005 
307 
ос 
001 
Ота 
012 
100 
036 
204 
370 
370 
016 
017 
106 
247 
004 
300 
300 
104 
275 
поё 
706 
ang 
37^ 
061 
307 
004 
aor 


076 
006 
100 
063 
оба 
370 
016 
015 
106 
247 
004 
104 
275 
004 
O76 
000 
061 
307 
004 
001 


O74 
ote 
100 
110 
004 
370 
016 
012 
106 
247 
004 
317 
104 
275 
ооё 
300 
006 
000 
370 
061 
307 
004 
001 


074 
006 
100 
137 
004 
370 
016 
007 
106 
247 
004 
зоо 
104 
275 
004 
006 
000 
370 
061 
307 
004 
001 
370 
061 
307 
074 
001 


10 HOUR DIGIT REGISTER 
HOUR DIGIT REGISTER 

10 MINUTE REGISTER 
MINUTE REGISTER 

10 SECOND REGISTER 
SECOND REGISTER 


LHI LOAD LZH WITH 

H(SEC) ADDRESS OF SECONDS 
LLI DIGIT REGISTER 
LUSEC) 

LAM INCREMENT SECONDS 
ADI DIGIT 

на" 

CPI DECISION: JUMP IF 
"ao" SECONDS DIGIT 15 NOT 
JFC LESS THAN 10 


t 
" GTENS 


МА RETURN SECONDS DIGIT TO 115 REGISTER 
LMA REPEAT INSTRUCTION FOR MORE TIME 

Lal 

"as" SET VALUE OF "x" 

CAL CALL TIME LOOP TO COMPENSATE 


L 
H |= оо 


МОР NEED А LITTLE MORE TIME 
NOP 
JMP FINISHED THIS CYCLE 


L 
н DISPL 


LAI 
"o" CLEAR SECONDS OIGIT REGIST 
LMA 

DEL 

LAM INCREMENT 

ADI 10 SECONDS DIGIT 

"qt 

CPI DECISION: JUMP [F 

"e" 10 SECONDS DIGIT I$ NOT 
JFC LESS THAN 6 


t 
t J~ somn 


LMA RETURN 10 SEC. DIGIT TO REGISTER 
LBI 

"їз" SET VALUE OF "x" 

CAL CALL TIME LODP 

M TLOOP 

JMP FINISHED THIS CYCLE 

M DISPL 

LMI CLEAR 10 SEC. DIGIT REGISTER 

"o" (АТ, UMA ARE USED INSTEAD OF LMI 
DCL WHERE TIMING WORKS OUT’ BETTER THAT wary, } 
LAM INCREMENT 

ADI MINUTES DIGIT 

"Qn 

CPI DECISION: JUMP IF 

"о" MINUTES DIGIT IS NOT 

JFC LESS THAN 10 


LMA RETURN MINUTES DIGIT TO REGISTER 
LBI 

"10" SET VALUE OF 

CAL CALL TIME LDOP 


LBM NEED AN EXTRA 12 uS. 
JMP (LBM - 32 US, OTHER 20 US BALANCED BY 
t [reeset 

H 

NOP 20 US BALANCE 

LAI 

"o" CLEAR MINUTES REGISTER 
LMA 

ось 

LAM INCREMENT 

ADI 10 MINUTES DIGIT 

mye 

CPI DECISION: JUMP IF 

"e" 10 MINUTES DIGIT IS NOT 
JFC LESS THAN 6 


"omm 
H 


LMA RETURN 10 MIN, DIGIT TO REGISTER 
LBI 

"IU SET VALUE DF "x" 

CAL CALL TIME LOOP 

" TLOOP 

NOP KEEPING THE TIME IN BALANCE 

JMP FINISHED THIS CYCLE 

L 

M DISPL 

LAI 

"o" CLEAR 10 MINUTES REGISTER 

СМА 

ось 

LAM INCREMENT 

ADI HOURS DIGIT 

"n 

LMA PUT THE HOURS DIGIT BACK FOR THE 
ось TIME BEING. 

LAM 

CPI DECISION: JUMP IF 


10 HOUR DIGIT = | 


767155 
9,156 
2057157 
20471606 
0657161 
5187162 
3947163 
5047164 
9047165 
0047166 
0047167 
9047/170 
0047171 
v047172 
0047173 
0047174 
0047175 
0047176 
2057177 
обале 
0904720] 
0067202 
0047203 
0047204 
пала 
ULETE 
a0az20T 
s687210 
c0Az211 
Das? 
0057213 
004/214 
UOSZ7215 
004/216 
0047217 
9047220 
0047221 
0047222 
0047223 
00457224 
0047225 
0047226 
0047227 
0067230 
0067231 
BÉSHOUR: 0047232 
6047233 
004/234 
0047235 
0047236 
0047237 
0047240 
0047241 
0047242 
0047243 
00457244 
0047245 
2044246 


GTENH: 


NOON: 


TLOOP: 004/247 
0047250 
004/25} 
0047252 
0047253 


QUIL: 004/256 
0047257 

004/260 

004/261 

0047262 

0047263 

0047264 

0047265 

004/266 

004/267 

0047270 

0047271 

0047272 

0047273 

004/274 

— DISRUTO047278. 
0057276 

(ғ) 0047277 
004/300 
0047301 
004/302 
0057303 
9047304 
004/305 
004/306 
7— 0047307 
Ө, 004/310 
0047311 
0047312 
004/313 
004/314 
0047315 
0047316 
0047317 
0047320 
0047321 
0047322 
- = 0057323 
LTIME: 0047324 
0047325 

LTIMI: 0047326 
004/327 

004/330 

0047331 

0047332 

0047333 

0047334 

004/335 

004/336 

0047END 


150 


213 L | - 
Эда ч NOON 


066 INL 
307 LAM 
07% CPI 
212 “ао 
109 JEC 


177 0v GTENH 
004 H 


307 LAM 
307 LAM 
307 LAM 
307 LAM 
307 LAM 
300 NOP 
300 NOP 
104 JMP 


DECISION; JUMP JF 

HOUR DIGIT 15 NOT 

LESS THAN 10 

NEED "**4 NOP IS ADDED TO BOTH BRANCHES 
та TO BALANCE THE TRUE BRANCH FROM 
WASTE 04/153. A BETTER PLACE FOR THE NOP 
200 US WOULD HAVE BEEN 04/156, BUT мно 
To WANTS TO REWRITE HALF A PROGRAM TO 
BALANCE SAVE ONE MEMORY LOCATION? 

BRANCH 


NOW LET'S GET GUT'A HERE 


275 imet 
ода н 


006 LAI 
ооо "о" 
370 LMA 
061 DCL 
307 LAM 
004 ADI 
oor "1" 
370 LMA 
300 NOP 
106 JHP 


27$ L 
004 H 


060 INL 
307 LAM 
074 CPI 
003 "3" 
100 JFC 


CLEAR HDUR OIGIT REGISTER 


INCREMENT 
10 HOUR OIGIT 


RETURN 


CYCLE FINISHED 


10 HR. DIGIT TO REGISTER 


ISPL 
DECISION: JUMP IF 
HOUR DIGIT IS NOT 


LESS THAN 3 


232 t 
004 H RESHOUR 


016 LRI 
nog "x" 
106 CAL 


SET VALUE OF 
CALL TIME LOOP 


x 


2a? L TLOUP 
ооа н - 


104 


JUMP TQ 004/275/036 


275 L 
004 H *^D1sPL 


006 LAL 
oor "1" 
370 LMA 
061 DCL 
006 LAT 
ооо "о" 
370 LMA 
241 мов 
043 RTC 
043 RTC 
104 JMP 


275 L 
004 H DISPL 


oll осв 
053 RTZ 
104 JMP 
247 L 

боо н 

307 LAM 
064 ORI 
обо "ав" 
121 бит 
026 LCI 
005 "5" 
106 CAL 
324 Jd 
004 H, 

031 DCD 
053 RTZ 
060 INL 
104 JMP 


CLEAR 


FOR TIME BALANCING. 


RESET HDUR DIGIT TO 1 


10 HOUR DIGIT REGISTER 


THAT'S NOT AN ERROR) 


THE NET DIFFERENCE 
US. 


(YES, 241 = 2451: 
BETWEEN BRANCHES FROM 04/7153 WAS 24 

2 X RTC = 24 US. THE NDB IS BALANCED 
BY THE NOP'S MENTIONED 


IN THE NOTE '"* 
SHORT TIMING LOOP 


СООР 


OUTPUT SUBROUTINE STARTS 
GENERATE ASCII] CHARACTER 


PRINT CHARACTER 


SET VALUE OF 
CALL LONG TIME LOOP 


LTIME 


ARE WE DONE PRINTING? 
CONTINUE IF NOT 


256 L пит. 
004 H, 


036 LDI 
006 "е" 
066 LLI 
000 "o" 
106 CAL 


SET UP COUNT - DISPLAY ROUTINE 


SET UP ADDRESS 


DUTPUT ROUTINE 


256 tovr 
004 H 


006 tal 
015 "i3" 
121 OuT 
026 LCI 
036 "зо" 
106 CAL 
зга L 

ооа н 

016 LBI 
255 "175" 
106 CAL 
247 

004 

104 JMP 


006 L 
004 н 


016 LB! 
377 "255" 
011 DCB 
110 JFZ 
326 ү = 
004 н 

021 pcc 
053 RTZ 
104 

324 

004 

SET 


WAIT UNTIL THE RIGHT TIME, 
IN AT 047006. 


INSTRUCTION 


LTIMI 


Кы 
L 

mnm 
H 


TME TIME A MINUTE OR TwO 


OUTPUT CARRIAGE RETURN COMMAND 


SET VALUE OF Y 
CALL LONG TIME LOOP 


LTIME 


SET VALUE OF "x 
CALL SHORT TIME LOOP 


[moor 
H 


JUMP BACK TO THE BEGINNING AND RECYCLE 


TART 


SET VALUE DF "x 


DECREMENT "x" 
JUMP BACK TO DECREMENT AGAIN 


IF "X" DOESN'T EQUAL 


DECREMENT “Y 
GO BACK TO PROGRAM 


REPEAT LOOP 


IF Y= о 


IN ADVANCE AT LOCATIONS 04/7005, 
AND START THE PROGRAM BY JUMPING 
THE PROGRAM 15 STOPPED BY LOADING A HALT 
INTERRUPT FROM THE FRONT PANEL. 
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YTE'S 


ITS 


Getting Started in TTL 


Digital logic is one of the 
many fascinating aspects of 
electronics. To date, TTL 
logic is the heart of almost 
every home brew computer 
system. Programming a 
computer is an exciting 
exploration into a mysterious 
world. Exploring the world of 
hardware that makes the 
programming possible is quite 
another exciting adventure. 
The best way to explore 
either of these worlds is not 
just through reading 
manufacturers data, but 
through experimenting for 
yourself. 

A TTL integrated circuit is 
a simple device by itself. 
When combined with a 
number of devices, a very 
complex system can evolve. 
Don't let the complexity of a 
computer system get you 
down. You don't need to be 
able to design computer 
systems to start having fun 
with TTL. Nor do you need 
be an electronic engineer. 
You don't need to know how 
to build automobile engines 
to get your car started, do 
you? 

To get started, you need 
only a few items. You will 
need a *5 volt power supply 
rated at 1 Amp or so. TTL 
integrated circuits do not 
require anything near 1 Amp 
each, but a number of ICs 
used together may add up to 
more than 1 Amp. 

The most convenient 
method for mounting and 
connecting integrated circuits 
is the use of a solderless 
terminal strip, the type 
advertised in BYTE and many 
other electronics 
publications. Only a little 
wire (22 or 24 gauge wire) is 
needed for interconnecting 
the TTL devices. 
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A good starting selection 
of TTL integrated circuits 
might include the following. 


world of 


Exploring the 
hardware with a dc power 


supply апа а solderless 
terminal strip. 


quantity type description 
2 7400 Quad 2-input pos. NAND gate 
2 7404 Hex inverter 
2 7408 Quad 2-input pos. AND gate 
2 7410 Triple 3-input pos. NAND gate 
2 7411 Triple 3-input pos. AND gate 
1 7420 Dual 4-input pos. NAND gate 
1 7421 Dual 4-input pos. AND gate 
1 7473 Dual! J-K flip flop 

The 7400 series part listed above are not the open 
numbers are standard. collector type. 


Different manufacturers may 
add one or two letters to the 
number, but it is still the 
same part. 


A TTL device has only 
three types of connections: 
Input, output and power 
supply terminals. The power 
supply terminals will be 
ground (GND) and Vcc. The 
voltage applied to Vcc should 
be +5 for proper operation. 


The inputs and outputs 
will always be in one of two 
states: HIGH or LOW. In the 
HIGH state, the voltage will 
be over 2.4 volts. In the LOW 
state, the voltage will be 
under 0.4 volts. Only a simple 
LED is needed for a state 
indicator. The circuit design 
physics are simple: Connect 
the output of one device 
directly to the input of 
another device, provided the 
TTL ICs used are not the 
open collector type. The ICs 


Your next most important 
item will be your literature. 
There are many details not 
discussed here which you will 
want to learn as you advance 
in TTL designing. There have 
been many books written on 
the subject of TTL. One very 
good book for hobbyists is 
Don Lancaster’s TTL 
Cookbook, which provides 
much information valuable to 
newcomers to the field, yet is 
detailed enough to be of great 
value even after you are quite 
familiar with TTL. 

A second source of 
information is a TTL data 
book, available from the 
manufacturers. Most TTL 
suppliers will supply data 
sheets for free or for a 
nominal fee. A data book isa 
complete collection of data 
sheets for all TTL 
manufactured by the 
company you obtained the 
book from. The data sheets 


or book will show the logic 
diagram, actual circuit 
diagram, pin connections, and 
circuit characteristics and 
functions for each TTL 
device. 

Your own experience 
should be proof that TTL is 
no more difficult than any 
other aspect of computers. So 


start planning your 
expedition! 
REFERENCE BOOKS 


ON TTL 


Texas Instruments Inc. 
PO Box 3640 M/S 84 
Dallas TX 75285 


TI supplies the following ex- 
cellent references. To order send a 
personal check or money order to 
the above address. 

LCC4200 Semiconductor 
Memory Data Book, $2.95. 

LCC4151 Linear & Interface 
Circuits Data Book, $3.95. 

LCC4111 TTL Data Book, 
$3.95. 

LCC4161 Supplement to the 
TTL Data Book, $1.95. 


TTL Cookbook, by Don Lan- 
caster. Howard W. Sams & Co., 
Indianapolis, Indiana, 1974. 
$8.95. See the review in BYTE 
ih, page 85, for details about this 
excellent introductory text and 
reference source. 


Use of ASCII Approved for 
Amateur Satellites 

The FCC has issued a 
Special Temporary Authority 
(STA) to the Radio Amateur 
Satellite Corporation 
(AMSAT) allowing the use of 
ASCII by radio amateurs 
through the communications 
packages aboard the OSCAR 
6 and OSCAR 7 satellites. 
The STA has been granted 
until Feb. 28, 1976. At the 
conclusion of this period, 
AMSAT will compile a report 
of the results of the 
experiments conducted and 


callsigns of the amateurs 
involved. More information 
can be obtained from 


AMSAT, Box 27, Washington 
DC 20044 phone (202) 
488-8649. 


Gary L. Tater WSHUC 
7925 Nottingham Way 
Ellicott City MD 21043 


Micro-440 

Computers come in all 
sizes. Here is a product made 
by COMP-SULTANTS inc., 
PO Box 1016, Huntsville AL 
35807. The product is the 
Micro-440 computer, based 
upon the Intel 4040 chip, and 
is to my knowledge the first 
such kit available. The photo 
shows an assembled version 
of the product, which costs 
$375 including 256 bytes of 
RAM program memory, 
power supply, cabinetry and 
displays. The entire CPU is 
constructed on one PC board. 
A kit version is available at 


Try to Duplicate This Using 
Magnetic Tape! 

William D. Roch (5133 
Catalon Ave., Woodland Hills 
CA 91364) sends in this 
sample of an ASCII character 
set translated into codes 
which will punch real dot 
matrix letters on paper tape. 
It provides a way for people 
with paper tape equipment to 
put a human-readable leader 
onto a tape prior to punching 
the usual data. 

In order to conveniently 
use this method, you'll have 
to make a table in memory to 
contain the full 6-bit ASCII 
subset shown in the table. 
Then you'll have to write а 
little routine to take a 
character string input 
parameter, look ир each 
character in the table, and 
output the appropriate 
sequence of codes. The table 


$275, and COMP-SULTANTS 
will sell partial kits as well. 


Information can be had 
for 25d in coin, or you can 
order the user's manual 
(440-U) for $10, which is 
refundable with an order for 
the product. 

The Intel 4040 instruction 
set operates upon 4-bit words 
in scratch pad register areas, 
and will prove adequate for 
many of the simpler program- 
ming applications readers 
might contemplate. It will 
prove to be an excellent 
learning machine at a fairly 
reasonable price. 


SPACE aaaaas 
әнә 
aGaGa 
a8J?J?Jà 
aRx7)Pa 


a>il>a 
a?xxZa 
a^!!Ra 
а?!!^ә 
а?хх!а 
а?ЕЕАӘ 
а^! Ha 
a?DD?a 
alata 

ӘР та 
a?LR!a 
a? a 

a7BDB7a 
a7BDH7a 
a?!!?68 
a?IIFa 
а^!1>а 

e?IYha 

av+iZa 

8AA?AAa 
a? ?a 

айр Pda 
a7PHP 2a 
alRLR!a 
@AB<BAa ? 
al)xea ? 


Won nw nu 


ug n n ü M n» u w u w n 


asB?Bsa 
al?8 
aLR!a 
a!RLe 
аХва 
axxa 
aBAIFa 
a HDAa 


" nwuw 


e VAGT tome l sem. xut 


| 
кан 


N<XELCANYDOVOZEC ACH rAAMIOOWyY 


ai? a 
aoxx"a 
alxxZa 
aHLJ?Hàa 
awx-Ya 
anxxXa 
aAAoGa 
aZzxZa 
aF1à 
anl іла 


"on nuu umo gu 


QOoo0«oubume 


lists what looks like gibberish, 
but when you punch out the 
sequences shown, you will see 


character patterns їп the 


holes on the tape. 


Creative Uses of DIP Header 
Plugs 

Sumner S. Loomis 
(Loomis Laboratories, Box 
131-A, Prairie Point MS 
39353) sends along three 
different examples of DIP 
header plugs used to mount 
components in existing 
circuitry. The first, A, is a 
plug-in substitute for an 
operational amplifier — а 
simple resistor used in an 
existing circuit which did not 
need the op amp. B is an 
example of how a socket can 
be attached to a DIP header 
plug in order to partially 
rewire a circuit without 
touching the original wiring. 


Several of the socket pins are 
bent and connected directly 
to the same pins of the plug. 
Other socket pins are clipped 
and rewired to different pins 
of the plug. By saving the 
original wiring, this technique 
leaves you the option of 
going back to the original IC 
— or you can use this 
technique to correct for 
errors in a PC board. The 
example of C shows several 
resistors mounted on the 
plug. This technique of 
mounting small discretes on 
plugs enables you to use 
sockets for these parts. It 
saves the hassle of installing 
individual wrapping posts. 


Notes 


As BYTE #4 goes to press, 
Electronic News (Sept. 29, 
1975) is running an 
advertisement for the 
Advance Micro Devices 
version of an 8080 design: 
The Am9080A. Significant is 
that the 100 quantity price of 
this chip is now down to 
$29.95, Price drops go even 
further than that — if you 
want to buy a million of the 
processors, you'll get a real 
bargain at $6 each. 


This is further evidence 
that the cost of silicon in a 
home computer is getting 
closer and closer to the cost 
of the iron used to contain it. 


ж жж 

" . .. But the roots of the 
software misery go deeper. It 
comes from the fact that 
people are forced to live with 
machines that they do not 
want. They have not 
constructed them, they 
simply receive them and have 
to make the best out of it... 
Thus, software engineering, 
for the time being, is partly a 


defense stratagem. But, | 
hope that some day this 
situation will turn around, | 
hope one day software 
engineering considerations 
will dictate how machines are 
to be built and then to be 
used..." 

Friedrich L. Bauer in the 

Preface to 

Software Engineering, An 

Advanced Course, 

Springer-Verlag Publishers, 

1973. 

Жжжж 

“А lot of comparisons have 
been made about how much 
faster computers сап do 
things than humans can. Here 
is another aspect of this 
comparison: To make all the 
errors a modern computer 
can make in 10 seconds, it 
would take a team of 30 
accountants working full-time 
for 50 years.” 

Barry W. Boehm, Guest 

Editor, 

IEEE Transactions 

Software Engineering, 

Vol. SE-1, No. 2 (June 

1975), p. 137. 


on 


Welcome, 
IBM, to 
personal 

computing 


With the announcement of 
the IBM 5100 system in a 
press release dated Sept. 9, 
1975, personal computing 
gains an entry from the 
industry's production and 
service giant, IBM. The IBM 
5100 is being marketed 
primarily as a problem solver 
for industrial, commercial 
and professional people — 
with the result that it is a 
very professional package at a 
premium price. But you will 
get a lot of function when 
you buy one of these 
computers — and you'll be 
able to call upon IBM's 
longstanding reputation for 
good service and customer 
handholding, the points 
which have led to the 
commendable success of ІВМ 
as a computer company. 

What IBM engineers have 
done is to design a 50 
lb-package of interactive 
personal computing which 
includes the following major 
features as standard items: 

ө System software is 
built-in, with access to 
BASIC and/or APL 
depending upon options 
purchased. These languages 
and the necessary monitor 
programs are hardwired into 
a read only memory. 

€ A video scrcen is built-in, 
with up to 1024 characters 
displayed in a 16-line by 
64-character format. 
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© An interactive keyboard is 
standard, including the 
usual text entry section as 
well as a separate calculator 
style keypad. The keyboard 
has special function coding 
for all the APL and BASIC 
syntax elements. 

@ User memory starts at 
16K bytes in the minimum 
configuration and can be 
expanded to 64K bytes 
(65,536). 

€ A magnetic tape cartridge 
storage device is standard. 
This is built into the unit, 
and becomes the primary 
method of storing user data 
and programs. It is also used 
to load IBM supplied 
programming packages. The 
cartridges for this device 
hold up to 204,000 
characters of information. 


You get all this function 
and professionalism from 
IBM by paying a high price. 
This machine is not intended 
to be a toy, although it would 
make an excellent one. It is 
intended as a production tool 
for people who presently use 
time sharing terminals, 
programmable calculators or 
other personal computers in 
daily work. Prices mentioned 
in the press release are: 

ө İBM 5100 processor ... 
$8975 to $19,975, 
depending upon user 
memory (16K, 32K, 48K or 
64K bytes) and language 
(APL or BASIC or both) 
options. 

e|BM 5103 printer 
$3,675 purchases an 80 cps 
132-column dot matrix line 
printer. 


e|BM 5106 Auxiliary tape 
unit ... $2,300 purchases 
an additional tape cartridge 
drive to augment the 
functions of the built-in 
drive. 

e ‘Problem Solver Library” 
software is available for a 
one time rental of $500 
including a wide range of 
utility and applications 
software with interactive 
user sequences. 


Miscellaneous features also 
available for the machine 
include a TV monitor output, 
the external 1/О adaptor used 
with the 5103 and 5106 
devices, a communications 
adaptor which makes the 
5100 emulate an IBM 2741 
communications terminal, 
and a carrying case. 

As an ІВМ  engincered 
product, you can expect a 
solidly built computer. If you 
are a business or professional 
person needing a high quality 
calculational and 
programming tool, then you 
should investigate the 5100 as 
an item of capital equipment 
— which you can incidentally 
use to program numerous 
BASIC games when you're 
not using it for business. But 
if your sole interest in the 
machine is as a luxury toy, 
you have to be moderately 
well off to purchase the IBM 
5100 at its present price. в 


THERES SOMEONE WHO WORKS FOR 
YOU WHO HAS CANCER. AND 
DOESNT KNOW IT. HELP FIND HIM. 


You don't know who he is. He 
doesn't know who he is. But 
there is a way to find him. 

By letting us help strengthen 
your employee health program # 
with our Employee Education 
Program. The purpose of the + 
program is simple. We want to ® 
save lives by exposing your 
employees to sound facts and 
recommendations for action 
about cancer. 

We'll supply free films, ex- 
hibits, speakers, pamphlets, 
posters, articles for your com- 
pany publications. 

We'll help you arrange 
“action” programs for your em- 
ployees...clinics to help ciga- 
rette smokers quit, instruction li 
in breast self-examination, à 
screenings for cervical cancer 
via the Pap test. All with one 
purpose: to educate your peo- 
ple about the lifesaving facts 
of cancer. 

Because if cancer is detected 
in its early stages, chances for 
cure are markedly increased. 

For more information contact 
your local American Cancer 
Society Unit. 

You will have helped to save 
someone's life. 

Maybe, even your own. 


AMERICAN 
CANCER SOCIETY 
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Oes. 


Hit the deck in shorts and 
a tee shirt. Or your bikini if 
you want. 


You're on a leisurely cruise 

to remote islands. With names 
like Martinique, Grenada, 
Guadeloupe. Those are the 
ones you've heard of. 


A big, beautiful sailing vessel 
glides from one breathtaking 
Caribbean jewel to another. 
And you're aboard, having 
the time of your life with an 
intimate group of lively, fun- 
loving people. Singles and 
couples, too. There’s good food, 
am гов; and a few pleasant 
' comforts...but there's little 
resemblance to a stay at a 
fancy hotel, and you'll be 
, | happy about that. 


Spend ten days exploring 
paradise and getting to know 
a ` congenial people. There's no 
. - other vacation like it. 
Your share from $245. A new cruise is forming now. 
Write Cap'n Mike for your free adventure 
booklet in full color. 


©) Windjammer Cruises. 


A WINDJAMMER INTERNATIONAL SUBSIDIARY * OTC 


Name 
Address 
City State ` 2р 
Рһопе 
P.O. Box 120, Dept. 121 Miami Beach, Florida 33139 
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And, we'll promise you only one thing. The most adventurous vacation you have 
ever experienced. Hop aboard our schooner for 10 sunfilled days and moonlit nights. 
A congenial group of shipmates now forming and setting their heading for Saba, 
Grenada, St. Lucia, Guadaloupe. And, Dutch St. Maarten. And, French Martinique. 
Explore pink, white and black sand beaches. Scale the cliffs, climb a volcano, prowl 
old forts and quaint towns. Hoist the sails, take a turn at the wheel or feet on the 
rail and let us do the work. Then limbo to a steel band and fall asleep under a star 
spangled Caribbean sky.Share from $250. If you have the spirit...come Windjammin:.: 
a true life adventure. This coupon will bring you a full color adventure brochure. 


Send me your color brochure on 10 day ‘barefoot’ vacations from $250. 


Name 


Address 


City State Zip 


€) Windjammer Cruises. 


Post Office Box 120, Dept. 00, Miami Beach, Florida 33139. 
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Fig. 1. One of the most convenient but permanent methods of assembly for experimental 
computer systems and logic designs is wire wrap construction using sockets and a general purpose 
prototyping board. This photograph illustrates an overall view of a partially wired Motorola 6800 
computer system fabricated on a board available from CELDAT Design Associates, Box 752, 
Amherst, N.H. This board provides a basic socket mounting matrix for 14 and 16 pin sockets plus 
a general purpose area in the center which will accept bigger sockets. 


The board which was photographed for this photo essay is the prototype Motorola 6800 system 
which is being designed and constructed for the LIFE Line application. 


by 


Photographic Notes on Prototype Construction zs 


94 


Fig. 2. As photographer Ed Crabtree zooms-in for a closer 
look, we see details of several useful techniques. These 
techniques can be used with any one of several brands of 
general purpose boards which are available from manufac- 
turers. 


Sockets can be mounted by carefully soldering the four corner 
pins of the pads in the socket patterns of the general purpose 
board. 


In the typical general purpose board, power and ground 
distribution is provided by alternate printed circuit strips on 
the wiring side of the board. Short jumper wires are wrapped 
to the socket pin and soldered to the appropriate bus as shown 
by the examples in the foreground. 


Before wiring, a sheet of paper can be punched with a socket 
pattern using a spare socket and some perforated board. After 
cutting the paper to size and writing an identifying number for 
the circuit, the resulting label is slipped over the pins. 


Several examples of two-level wire wrap interconnections can 
be seen in this photograph. The typical wire wrap post can 
accommodate three levels but good practice limits the use to 
two levels as a general rule. | 


subscription and get him off your back. You know darned well that he isn’t going to give 
you back your magazine, so be practical about it. 

Subscriptions are only $12 cheap enough to spread joy and fun among a few friends 
— like for Christmas. Tell you what - the second and onward subscriptions will only be 
$10 — Christmas Special — good until the end of the year, 

A subscription makes a great Christmas present because the recipient gets a reminder 
every month for a year of your thoughtfulness, 

Be a saint. 


E The next time a friend wanis to borrow your BYTE sit right down and buy him a 
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Fig. 3. It is good construction practice with logic circuitry to heavily bypass the 
logic power supplies. This is especially true of TTL logic, but applies as well to any 
of the alternative logic families. This photo shows how a typical ‘‘decoupling 
capacitor" of .1 uF is connected between a power bus and the ground plane of the 
board. The power bus runs between the rows of integrated circuits. 


Fig. 4. A technique which is 
often useful in wiring a neat 
board is the use of wiring 
guides. This photo illustrates 
one very inexpensive way to 
make such a guide — bend a 
short piece of wire such as a 
clipped resistor lead to shape 
then solder it to the 
prototyping board's ground 
plane. In this picture the 
wiring guide is shown before 
any wires have been added in 
its vicinity. 
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Fig. 5. As wiring progresses, 
the wiring guides placed at 
strategic places on the board 
come into use and become 
filled with bundles of 
interconnection wire as in 
this photograph. After the 
system is completely 
debugged, the two ends of 
the guide can be bent down 
over the bundle. Until then 
they are left open at the top 
so that new wires can be 
slipped in. 


THE | 


CURVE TRACER 


THAT WONT 
COLLECT DUST. 


"I 


The Hickok Model 440 
semiconductor curve tracer is 
all purpose and convenient to 
use. It’s the ideal instrument for 
testing, evaluating, classifying 
and matching all types of 
transistors, FET's and diodes. 
You'll get stable, full range 
dynamic displays that you can 
accurately scale right from 
the screen. 


= Pull-out card for easy, fast 
set-up and operation. 


= Set-up marks for rapid set-up 
of 80% of tests. 


Unique INSTA-BETA display 
takes the guesswork out of 
transistor and FET parameter 
measurement. 


п |n-or-out of circuit testing. 


и A full range professional 
tracer at a price you can 
afford. 


AT YOUR DISTRIBUTOR 516500 


HICKOK 


the value innovator 


INSTRUMENTATION & CONTROLS DIVISION 
THE HICKOK ELECTRICAL INSTRUMENT CO. 
10514 Dupont Avenue « Cleveland, Ohio 44108 
(216) 541-8060 • TWX: 810-421-8286 


ALTAIR OWNERS 


CMR PRESENTS 
THE MEMORY YOU'VE BEEN 
WAITING FOR 


8K x 8 DYNAMIC RAM 


ON ONE PLUG-IN CARD FOR 


ONLY $59900 ж 


e FACTORY ASSEMBLED AND TESTED 

e PLUGS INTO 8800 WITH NO MODIFICATIONS 

@®PROTECT-UNPROTECT CIRCUITRY INCLUDED 
TO MATCH 8800 

ө TWO 4k BLOCKS OF DYNAMIC R.A.M. 

e USER OR FACTORY ADDRESS PROGRAMMING 
(SPECIF Y) 

€ EACH CMR-8080-8k is SHIPPED WITH AN EDGE- 
BOARD CONNECTOR INCLUDED. 

€ EXPANDER BOARDS AVAILABLE (ADDS FOUR 
SLOTS TO 8800) 


TEN REASONS TO CHOOSE 
THE CMR MEMORY CARD 


1. 300ns ACCESS TIME 

2. TWICE THE MEMORY DENSITY 

3. LESS $$ PER K OF MEMORY 

4. DESIGNED FOR THE 8800 

5. USES THE LATEST Т.І. CHIPS 

6. G-10 EPOXY BOARDS 

7. PLATED THROUGH HOLES. 

8. GOLD PLATED CONNECTOR CONTACTS. 

9. 8192 WORDS OF DYNAMIC RAM 

10. 90 DAY WARRANTY ON PARTS AND LABOR 


*ORDERING NOTE: 

FOR FACTORY PROGRAMMING. SPECIFY TWO 4k 
MEMORY ADDRESS LOCATIONS FOR EACH CMR-8080-8k 
MEMORY CARD ORDERED. 


MAIL THIS COUPON TODAY 


LI ENCLOSED IS CHECK OR M.O. FOR $ 
[] C. O.D. s ACCEPTED WITH 30% DEPOSIT. TOTAL 
AMOUNT $.—— ——— — 30% = 

VA. RESIDENTS ADD 4% 
@ PLEASE SEND CMR-8080-8k CARD(S)* AS 
DESCRIBED ABOVE @ 599.00 EA. POSTPAID 
@ PLEASE SEND EXPANDER BOARD(S) 
{ADDS 4 SLOTS TO 8800) BOARD ONLY @ 15.00 EA. 
POSTPAID TO: 


NAME 
ADDRESS 
СІТМ_______ STATE & 21Р. 


CMR COMPUTER MANUFACTURING CO. 


P.O. BOX 167, 1921 DOGWOOD LANE 
VIENNA, VIRGINIA 22180 
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What You Can Do With an Oscilloscope Graphics Display 


Sumner Loomis, Route 1, Box 131, Prairie Point MS 
39353, supplies us with some additional illustrations of what 
can be done with the oscilloscope graphics display unit he 
built based upon the design of Jim Hogenson in BYTE #2. The 
barking poodle is self-explanatory. The second picture is a 


histogram of some experimental data which is being displayed 
by the graphics output device. 


BARKING POODLE 


16K MEMORY KIT 
LESS THAN 5.5¢/WORD 


16,384 8-BIT WORDS ON 
ON ONE CARD WITH PIGGY-BACK ONLY 


$895.00 


@ PLUG DIRECTLY INTO 8800 

@ LOW POWER: + 8TO+10V, LESS THAN 600 mA 
+15 TO +18V, LESS THAN 100 mA 
—15 TO—18V, LESS THAN 30 тА 

e TOP 4K WITH PROTECT-UNPROTECT 

© USES LOW POWER SCHOTTKY TTL 

© MEMORY CHIPS SOCKET MOUNTED 

e 50/50 GOLD-PLATED EDGE CONTACTS 

e EPOXY BOARDS WITH PLATED THRU HOLES 

e JUMPER PROGRAM 16K ADDRESS SLOT 

e 8080 HOME BREW COMPATIBLE 

€ 420n8 ACCESS DYNAMIC RAM 

@ NOT A FLAKE 


INTRODUCTORY SPECIAL ON ORDERS 


RECEIVED BEFORE 1/1/76 
@@ Take $50 Discount 9€ Take Free 50/50 Edge Connector 
@@ Pay No Shipping Charges 


WRITE TO DAVE (K6LKL) at 
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*SPECIFY KIT 16KMDY 


DUTRONICS 


P.O. Box 9160, 
Stockton CA 95208 


*MASTER CHARGE — OK 
*BANKAMERICARD — OK 


*CALIF. RES. ADD SALES TAX 


Course in Virginia 
À course entitled "Digital 
Electronics for Automation 
and Instrumentation" will be 
given at Virginia Polytechnic 


institute and State 
University, Blacksburg VA, 
on Dec. 7-12, 1975. 


Instructors are David G. 
Larsen, Dr. Peter R. Rony, 
Jonathan A. Titus and Dr. 
Frank A. Settle Jr. The 
course uses Bugbooks 1, 17 
and /// as text (see review of 
Bugbook 11 on page 108). 
The course is an "'in-depth 
laboratory/lecture course 
[which] provides hands-on 
experience with the wiring of 
digital circuits of modest 
complexity involving popular 
and inexpensive TTL 
integrated circuit chips ..." 
Enrollment is limited to 24 
persons, $325 to members of 
the American Chemical 
Society, $360 to 
non-members. To register or 
obtain additional 
information, contact Harold 


рор рр рр рр НИ ЕУ 


Walsh at the Education Dept., 
American Chemical Society, 


1155 16th St., N.W., 
Washington DC 20036 
(phone 1-202-872-4600). 


Technical questions about the 
course can be answered by 
calling Mr. Larsen at 
1-703-951-6478 or Dr. Rony 
at 1-703-951-6756. 


Out of Context... 

A. M. Biguity provides 
BYTE with the following 
note which he found in the 
Fairchild Semiconductor 
34000 Isoplanar CMOS Data 
BooR, page 2-8: 

"[ndividuals and tools 
should be grounded before 
coming in contact with 
34000 devices...” 


“The trend is to stay upwards 
compatible with all previous 
bugs." 
Prof. Niklaus Wirth in a 
1972 compiler 
construction course at 
Stanford University. 


JAMES ELECTRONICS 


Р.О. BOX 822 BELMONT. CALIFORNIA 94002 
(415) 592-8097 


WALL or T.V. DIGITAL CLOCK 
12 or 24 Hour, 25° VIEWING DISTANCE, Walnut Case-6"x3" x17 


POCKET CALCULATOR KIT 
§ function plus constant—addressable memory with 


individual recall—8 digit display plus overflow— 
battery saver—uses standard or rechargeable batteries— 


all necessary parts in ready to assembly form— 
instructions included. 3"x 5%" bee 
SPECIAL $12.95 each ` 


OPTIONS- 115VAC Transformer........- 4.95 each 
6 each "N" Alkaline Batteries... . 1.95 lot 


тон pat mdnpenstie tese LOGIC PROBE 


logic fames, TTL, DTL. RTL, CMOS. h 


ах. a MAN resdou! - 
indicate any of the following states by these 
symbols: {411-1 (LOW)-o (PULSE]-P. The n 
Probe can detect high frequency pulses to U 
45 MHz. It can't be ae at MOS levels or 


circuit датада will resui 


$9.95 Per Kit 


printed circuit board 


MINI POWER SUPPLIES 


These power supplies offer small size, with a wide choice ot voltage outputs. 
They are all capable of delivering 300mA and have dimensions of 1" x 1" x 3", 
The voltages available are 45V, -SV, +6V, -6V, +12V, —12V. АН of these units 
easily assemble in less than s half an hour, because of the fiberglass printed 
circuit board construction. Please specify voltage when ordering. 


$9.95 per kit 


LOW COST DIGITAL CLOCK KIT 
‘thar companies have offered а tow cost digital clock kit, but do not offer 
mportant extras such as, printed circuit boards, power supplies cases, eic. We 
at James are daing just the opposite by offering à complete clock kit, that 
includes everything down to the line cord. This kit uses .25" ЕМО 70 displays, 
for HOURS, MINUTES, and SECONDS, in conjunction with the MM5314 clock 
chip. The printed circuit board is of high quality fiberglass, which is piated. The 
case is a B x 1% x 1 walnut case with a plexi-glass front, and is similar to the one 
in out TY WALL Digital clock. |t is available withaut the case for $16.95. 


$19.95 per kit. 
ELECTRONIC ROULETTE 


Complete kit 
with all 
components 
WEE] case and 
transformer. 


А 56 page book on the facts |__| 
of Roulette included. $29.95 Per Kit 


ELECTRONIC CRAPS 


S) Complete kit 
6" X 35" x a 


with all 
components 
A 56 page book on the facts | 
of Craps included. $19.95 Per Kit 


case and 
transformer. 


Satisfaction Guaranteed. $5.00 Min. Order. U.S, Funds. 
Add $1.25 for Postage — Write for FREE 1975  Cotalog 
California Residents — Add 6*5 Sales Tax 


“GAMES 


BOX 822, BELMONT, CA. 94002 
PHONE ORDERS — (415) 592-8097 


DIGITAL 
PERFORMANCE 
YOU CAN RELY ON. 


The Hickok Model 334 DMM is 
a rugged, non-temperamental, 
hardworking tool that's easy to 
use and easy on your eyes. 
Hickok has established a unique 
reputation in digital electronics 
during the past 10 years. The 
Model 334 is another example 
of our engineering expertise — 
an economical lab quality 
instrument with exceptional 
durability and accuracy. 


m Easy reading, green 
fluorescent display 


и 3% digit — auto polarity 


26 ranges including 200 mV 
AC & DC ranges 


Fast response — 
2.5 readings/sec 


Basic Accuracies (96 of reading) 
DC Volts; +0.2% (50.5% оп 200V, 
1200V ranges) 
AC Volts; +0.5% (+2.0% on 
200 mV, 2V ranges) 
OHMS; 20.596 
DC Current; 41.5% 
AC Current; +2.0% 


AT YOUR DISTRIBUTOR $22900 


HICKOK 


the value innovator 


INSTRUMENTATION & CONTROLS DIVISION 
THE HICKOK ELECTRICAL INSTRUMENT CO. 
10514 Dupont Avenue « Cleveland, Ohio 44108 
(216) 541-8060 • TWX: 810-421-8286 


"I have always wanted lo бам 
fox a magazine, but I'm only 
12 years old. Your magazine 
has lads drawang for it and 1 
Sid. This is my big break . 


Eric Stewart 


Clubs and Newsletters 


San Diego Club Activities 
The San Diego Computing 
Society (for lack of a more 
permanent name) sent BYTE 
a copy of an August 1975 
newsletter. The newsletter 
included information on club 
activities as well as a lengthy 
and wide-ranging comparison 
of various alternatives for 
microprocessor users, written 
by member Dr. Michael 
Hayes. The article covered 
possible choices from existing 
uP evaluation kits to the 
151-11. News of club 
activities included a 
scheduled meeting with 


speakers from Processor 
Technology Inc. to 
demonstrate their products 
which included the new 
TV-Dazzler color television 


graphics display device. For 
information on the San Diego 
Computing Society, write: 

Gary Mitchell 

Box 35 

Chula Vista CA 92012 
Membership dues (which 
bring the newsletter to your 
mailbox) are $2.50. 
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Southern Florida Club? 
Roberto R. Denis (11080 
N.W. 39 St., Coral Springs FL 
33065) inquires about club 
activity in southern Florida. 
He's interested in contacting 
persons and starting a club. 


Denver Amateur Computer 
Society 


George Mensik, proprietor 
of Gateway Electronics in 
Denver, called BYTE as #4 
goes to press. He reports a 
large and active Denver Ama- 
teur Computer Society exists 
(over 100 members) with 
interest in computer 
activities. The DACS 
meetings include talks by 
industry people as well as 
tutorial sessions and special 
interest gatherings. George’s 
store also serves as a general 
meeting ground for the 
Denver area. 

You can find out about 
the DACS by contacting 
George at Gateway Elec- 
tronics, 2839 W. 44th Ave., 
Denver CO 80211 (phone 
1-303-458-5444), 


News from the Southern 
California Computer Society 
The September 1975 issue 
of /nterfuce, the SCCS's lively 
newsletter, arrived as BYTE 
#4 was being assembled in 
late. September. The SCCS 
people have put together an 
excellent and informative 
club letter — running 15 
pages in the Vol. 1 No. 1 
issue, just for September. In 
addition to reports on club 
business matters, the major 
portion of the letter concerns 
information and background 
data of general interest. The 
newsletter is sent to 
members. To become a 
member, send $10 annual 
dues plus your complete 
name, address, zip and 
telephone information to: 


Southern California 
Computer Society 

PO Box 987 

South Pasadena CA 91030 


In phone conversation with 
Hal Lashlee of SCCS 
(1-213-682-3108) BYTE 
learned a few details of the 
group purchase of Digital 
Equipment Corporation 
151-11 computer equipment. 


The basic deal is that the 
SCCS will роо! individual 
orders for the DEC 


equipment to obtain quantity 
discounts at the 50-, 100- and 
possibly 200-level price 
breaks. Orders will be made 
initially on the assumption of 
50-quantity purchases, at the 
following prices for 
equipment: 


LSI-I1 CPU (4K x 16 
memory, PDP-11/40 
instruction set), $653. 


LA-36 DECWriter (30 CPS 
terminal), $1480. 


The SCCS is in the process of 
securing a fidelity bond for 
the offer, and, according to 
Hal, has made arrangements 
for MasterCharge and 
BankAmericard payment for 
orders. A fee for the service — 
intended as a contribution to 
the club’s activities — is set at 
a minimum 2% of the order 
value. Larger contributions 
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are of course solicited to help 
pay for the club’s operation. 

It also looks as if the SCCS 
will be starting the first active 
LSI-11 computer users group 
as a result of this purchase 


activity. 
If you're interested, Hal 
says that inquiries 


accompanied by a large self 
addressed stamped envelope 


should be sent to the 
Southern California 
Computer Society at the 


address above. 


New England Computer Club 

An organizational meeting 
of the New England 
Computer Club has been 
scheduled for Nov. 5, 1975. 
A tentative meeting place, 
arranged by Ted Poulos of 
Brookline MA, is at the 
Jarrell-Ashe plant, Waltham 
MA. Boston and southern 
New Hampshire area 
computer hackers who want 
to be on the mailing list for 
future meetings should send 
their name and address 
information on an index card 
or IBM card to: 


New England Computer Club 
c/o BYTE Magazine 
Peterborough NH 03458 


Chicago uP Users Group 


The Chicago Area 
Microcomputer Users Group 
met for the first time in 
September, with about 30 
attending. For latest 
information, contact Bill 
Precht, 1102 S. Edson, 


Lombard IL 60148. 


MC 14412 UNIVERSAL MODEM CHIP 
MC14412 contains a complete FSK modu- 
lator апа de-modulator compatible with 
foreign and USA communications. (0 — 600 
BPS) 

FEATURES: 

9 On chip crystal oscillator 

© Echo suppressor disable tone generator 

© Originate and answer modes 

© Simplex, half-duplex, and full duplex 

Operation 


9 On chip Sine Wave 

€ Modem self test mode 

© Selectable data rates: О — 200 
0 — 300 
0 — 600 


9 Single supply 
VDD = 4.75 to 15 V DC -FL suffix 
VDD = 4.75 106 V DC-VL suffix 
TYPICAL APPLICATIONS: 
9 Stand alone — low speed modems 
9 Built-in low speed modems 
® Remote terminals, accoustical couplers 


МС 14412 FL... ce ee eee 28.99 
MC 14412 VL ................... 21.74 
6 pages of data ................... .60 
LED Mounting Hardware 
(Specify bezel color) 
1750-04 (4 readout) .............. $ 7.00 
1750-06 (6 readout) .............. $ 9.00 
1750-08 (8 readout) .............. $11.00 


Screen available in red, amber or neutral color 


2102-1 MEMORY 
1K fully encoded fast (500ns) MOS RAM. 


New factory prime parts .. . $4.15, 10/$39.00 


MC14411 Bit Rate Generator. Single chip for 
generating selectable frequencies for equip- 
ment in data communications such as TTY, 
printers, CRT's or microprocessors. Generates 
14 different standard bit rates which are 
multiplied under external control to 1X, 8X, 
16X or 64X initial value. Built-in crystal 
oscillator circuit. Operates from single +5V 
supply. 

MC14411P with specs 


Clock Chip. The MM5318 is an excellent 
choice for TOD clock all by itself. The display 
interface has externally selectable character. 
This allows for outputting one digit at a time 
to the BCD or 7 seg busses under external 
control. Useful for computer real time clocks, 
TV display, serial character transmission. With 
specs. 

MM5318 Clock Chip 


-Skt-1802... 


RECEIVER 
TRANSMITTER 


UART-1013A is an ideal device for driving 
computer peripherals such as teletypes & 
video terminals. NEW, factory fresh parts. 
Made by General Instruments. Full specs. 
New low price! 


URT-1013A $10.95, 2/$19.95 


National MM5740AAE. Complete keyboard 
interface system capable of encoding 90 single 
pole single throw switch closures into 9-bit 
ASCII code. Silicon gate technology and is 
TTL input compatible. Has N Key rollover, 
one character data storage, repeate function, 
capacitor key bounce masking, with spec 
sheet. 

MM5740AAEN 


INTERSIL 8038CC 

Precision Waveform Generator/Voltage Con- 
trolled Oscillator. 

Wide Frequency Range of Operation 0:001 
Hz to 1.5 MHz 

Variable Duty Cycle 

#1С8038 . . . with specs 


7 SEGMENT DECODE/DRIVER/LATCH 


Fairchild 9374 TTL/MSI is a 7 segment 
decoder driver incorporating input latches and 
output circuits to directly drive common 
anode LED displays. Constant current 15 mA 
sink eliminates need for matching resistors. 
Automatic zero blanking. Transparent latches. 
Pin compatible with SN7447. 

FDL-9374 


TV CLOCK CHIP SET. Display time of day 
directly on your TV screen. MM5318 and 
ММ5841 ICs form the basis for video display 
clock. 5318 keeps time of day (4 or 6 digit) 
and 5841 provides dispiay video signals with 
sync derived directly from your set. Makes 
most interesting way to tell time of day 
during TV hours. 

MM5841/MM5318 Set with specs 


hd 


IC SOCKETS. ' HIGHEST QUALITY! 
PC Mount . . . Solder Tail 

Skt-0802...8 ріп... 254, 10/$2.25 
Skt-1402...14 pin... 26¢, 10/$2.40 
Skt-1602... 16 pin... 30¢, 10/$2.70 

18 ріп... 454, 10/$4.25 
Skt-2202...22pin... 604, 10/$5.50 
Skt-2402...24 pin... 654, 10/$6.00 
Skt-4002... 40 ріп... $1.25, 10/$11.00 
Wire Wrap Tails 
Skt-1400. .. 14 pin... 
Skt-1600... 16 pin... 


... $20.80 


494, 10/$4.50 
554, 10/$5.00 


EXAR! 

XR-320 Precision timer $1.55 
XR-2240 Prog. Counter/timer 4.80 
XR-210 FSK Demodulator PLL 5.20 
XR-205 Waveform Generator 8.40 
XR-2206 Function Generator 5.50 
XR-2207 VCO 3.85 


EXAR XR-2206KA Function Gen Kit. 
Includes monolithic function generator IC, PC 
board, parts list and assembly instruction 
manual ........................ $19.95 


PRECISION LAB QUALITY REGULATOR 
MC1466L chip can be used to build a high 
quality voltage and current adjustable power 
supply. Available output current limited only 
by the supply and the number of pass 
transistors. Floating type regulator allows 
voltage variation from O to 250V! .01% line 
and toad regulation. 
MC1466L w/specs 


DUAL + 15V TRACKING REGULATOR 
MC1468L 14 pin DIP Package. 
FEATURES: 
"Output current to 100 mA ` 
*Line and load reg. .06% 
‘External adj 8 to 20V 
*Remote sensing 
MC1468L w/specs 


T0-92 VOLTAGE REGULATORS 

If your project needs only 100 mA or less, use 
these tiny plastic regulators right on your PC 
board. Same size as a plastic transistor. Save 
space and $. Last 2 digits denote voltage 
(positive). 

LM78L05, LM78L12, LM78L15. 85d 


1/2A Regulator. Fairchild 78MGT2C positive 
and 79MGT2C negative regulators are adjust- 
able from 5V to 30V with only 2 external 
resistors. Only 1 resistor for +5V (*.2V) from 
the 78 MGT2C. Comes in 8 pin minidip 
package format with heat tabs for attaching 
to PC board or heat sink. Easily connected for 
+ tracking supplies. 

78MGT2C (pos) or 79MGT2 (neg) $2 


5V, ЗА TO-3 Regulator. Fairchild SH323KC 
monolithic regulator in TO-3 power package. 
Use it with the same ease of installation as the 
famous 309K (same pin arrangement). Take 
care of those heavy current requirements 
without separate regulator/pass transistor 
combinations. 


SH323K3 5V, 3A $9.95 


MINIATURE ROCKER DIP SWITCHES 

Dual in-line SPST switch arrays for P.C. 
mounting. Spring loaded sliding ball contact 
system for positive, tease proof contact. 
Comes in contact arrangements from 4 to 10 
per pack. Fits standard DIP sockets. Last two 
digits of stock # indicate number of switches. 


DIS-76B04 .................... $3.10 
DIS-76B06 .................... $3.50 
DIS-76B07 .................... $3.75 
DIS76B08 .................... $3.95 
DIS-76B10 .................... $4.35 


TRI т tek, INC. P.O, BOX 14204, DEPT 7 PHOENIX, ARIZONA 85063 
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THE 6000 SERIES 
COMPUTER FAMILY 


OHIO SCIENTIFIC INSTRUMENTS IS NOW OFFERING A COMPLETE 
LINE OF PIN COMPATABLE BUS ORIENTED 8BIT 1Mhz MICROPROCESSORS 
AND SUPPORT CHIPS BY MOTOROLA, AMI, MOS TECHNOLOGY AND OTHERS. 


EACH MICROPROCESSOR COMES COMPLETE WITH SUPERBOARD: 

А COMPLETE MINICOMPUTER P.C. BOARD (DOUBLE SIDED EPOXY) 

WHICH ACCEPTS ANY 6000 SERIES PROCESSOR, SYSTEM CLOCK, 

2- 1702 TYPE ROMS, 1K X 8 RAM (2102 TYPE), 1 PIA, 1 АСТА, CURRENT 
LOOP AND PARALLEL INTERFACES AND HAS BUS EXPANSION CAPABILITIES. 


99°° 
49° 


54° 


6800 an SUPERBOARD- "THE TOP OF THE LINE" 


6 5 О 1 AND SUPERBOARD- DIFFERENT INSTRUCTION 
SET, BUT JUST AS FAST 


6 50 2, SUPERBOARD- А 6501 WITH INTERNAL 
CLOCK 


ALSO AVAILABLE- 
SYSTEM MONITOR ROMS, PROMS, RAM, PIAs, АСІАв, UARTs, 
AND BUS TRANSCEIVERS 
RAM- ROM MEMORY EXPANDER BOARD 
SUPER I/O BOARD CONTAINING CASSETTE INTERFACE; X,Y DISPLAY 
AND A/D CONVERTER. 


COMING SOON- 
VIDEO GRAPHICS BOARD 
FIRMWARE BASIC BOARD (USES ROM AND CALCULATOR CHIP) 


ALL CHIPS ARE FULL SPEC. INDUSTRIAL QUALITY COMPLETE WITH FACTORY 
SPEC. SHEETS, SUPERBOARD, AND OUR OWN APPLICATION SCHEMATICS 
AND NOTES. 


CALL (216)-653-6484 OR WRITE TODAY FOR OUR FLYER AND OUR NEW 
APPLICATIONS NOTE "THE 6000 SERIES BUS." 


OHIO SCIENTIFIC INSTRUMENTS 


P.O. BOX 374, HUDSON, OHIO 44236 


computerized 


j Assemble your own electronic 
Ping-Pong unit that connects 


to any TV. It’s easy! 
Complete plans, p/c boards, 
preassembled & finished units. 
Our designs inctude challenging 
game action, a computer- 
control paddle sound effects 

& on-screen scoring. Exciting! 


Build the basic unit for about 
$40 in common components. 


Send $27.50 for “Superset” 
p/c board (with aligned horiz. 
& vert. oscillators) & plans... 
or... send $1.00 (refundable) 
for circuit diagram & info 
packet of p/c boards, plans, 
accessories & completed units. 


$1 for schematic diagram & info 
pack (refundable on purchase), 


viste 


MOUNTAIN VIEW, CA 94040 


e. 


(= m m и а а a a a 
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NEVER YOU MIND 


OCCUPANT 
BOX BYTE 
PETERBOROUGH 
NH 03458 


BIT COLLECTING 


Editor, 


First let me congratulate 
you and your staff on an 
extremely interesting and 
informative first issue. It is 
definitely the best first issue 
of a magazine that I have ever 
read. I, like thousands of 
others, decided on 
subscribing to BYTE after 
collecting a few bits of 
information concerning what 
you intended to publish. I 
was very pleased to see that 
you managed to get all the 
bits together to form a 
BYTE! I believe that while 
the MITS people have set the 
standard for “the affordable 
computer,” the BYTE people 
are now setting the standard 
of how to educate people in 
using it! 

I was particularly 
interested in the comments of 
one reader regarding the 
playing of games between 
computers. I intend to 
develop a CHESS program for 
my Altair 8800, probably in 
MITS 8k BASIC language. I 
would like to correspond 
with all the people out there 
who share the same interest. 
While on this topic, I should 
say that I would like to see 
some competitions between 


small computers classified 
according to соге size, 
instruction set, cost ог 


whatever else will encourage 
people to pack the most 
efficiency and genius into the 
lowest cost system. 

In closing, I must make 
one final observation. I 
noticed in Don Lancaster's 
article on ‘‘Serial Interface,” 
p. 35 (BYTE #1], that the 
originate modem tx and 
answer modem rx frequencies 
do not agree as is necessary 


for proper operation. The 
answer modem receive 
frequencies should be 1070 
Hz space and 1270 Hz mark. 
Incidentally, I thought the 
article by Don was of his 
usual high calibre and should 
serve as an example for others 
to follow. 


Dan Clarke 

105 Fir Court 
Fredericton NB 
Canada E3A 2E9 


DOWN ON EARTH? 
Editor, BYTE: 


I ordered my subscription 
to BYTE when the first ad 
was printed in 73 Magazine 
last summer. The first book I 
got was #2 (October 1975). 
Where is my #1? Please send 
it. 

I have a good 
understanding of analog and 
logical circuitry — i.e., gates, 
counters, shift registers, 
radio, ТУ and machine 
control. But — 

The only down on earth 
articles from which I got the 
full meaning in issue 2 were 
“Television Interface” (best 
by far) "Quick Test of 


Keyboards,'' and 
* Asynchronitis." 
Please — I want to 


understand 8008 and 8080. 
What's inside, relating to the 
logic 1 know? When are they 
called for? And what must be 
used with them? 

Most articles start in the 
process of program 
development — much too late 
for the beginner. It seems 
many cute words add to the 
snow: Like byte, Basic, life, 


architecture, kluge??, 
algorithm, subroutines, 
language — various, 


5% OFF ON ORDERS OVER $50.00 
10% OFF ON ORDERS OVER $100.00 
15% OFF ON ORDERS OVER $250.00 


DECEMBER SPECIALS 


9 DIGIT LED DISPLAY FNA 37 


TTL р On multiplexed substrate, comm. са- 

z5 t / thode compatabl ith all 8 digit 
7400 $ 14 7453 oce compatable w A (В! 
7401 16 7454 calculator chips, 7 segment right hand 
7402 .15 7460 decimal, red with clear magnifying lens, 
7403  .16 7464 .12" character, 110 4 MA, 1.8 V typ 2s" x 
7404  .19 7465 u” x 7" high |. 


LINEAR 

324 $1.19 
380-8 1.09 
565 1.49 
739 89 
75491 39 


7405  .19 7470 
7406  .35 7472 
7407  .35 7473 
7408  .18 7474 
7409  .19 7475 
7410 — .16 7476 
7411 25 7483 
7413  .55 7485 
7416  .35 7486 
741  .35 7489 
7420 .16 7490 
7422 26 7491 
7423  .29 7492 
7425 .27 7493 
7426 .26 7494 
7427 .29 7495 
7430 .20 7496 
7432 23 7410 
7437  .35 74105 
7438  .35 74107 
7440 17 74121 
7441  .98 74122 
74432 .77 74123 
7443  .87 74125 
7444 .87 74126 . 
7445  .89 74141 1.04 
7446  .93 74145 1.04 
7447  .89 74150 .97 
7448 1.00 74151 .79 
7450  .17 74153 .99 


LOW POWER TTL 


7400 $ .25 7451 $ 29 
74102 25 74155 
74L03 25 74171 
74104 25 74172 
7% 25 74173 
74110 25 74174 
74120 B 74178 
74130 B 74L85 
74142 E 74L86 


HIGH SPEED TTL 


74H00 $ 325 74H21 $ 25 
73H01 35 74H22 
74H04 74H30 
74H08 . 74H40 
74H10 . 74H50 
74H11 . 74H52 
74H20 . 74H53 


8000 SERIES 


8091 B 8214 
8092 E 8220 
8095 В 8230 
8121 Ё 8520 
8123 Ё 8551 
8130 B 8552 
8200 2. 8554 
8210 2. 8810 


9000 SERIES 


9002 $ .35 9309 
9301 1.03 9312 


7AC 162 
74C163 
74C164 
74C173 
790195 
80C95 
80C97 


MEMORIES 

1702A $14.95 
2101 2.95 
2102-1 3.25 
2102-2 3.25 
5203 12.95 
5260 99 
5261 99 
5262 2.95 


NINE DIGIT SPERRY 
GAS DISCHARGE DISPLAY 


SP-425-09 1.25” x 3" overall — .25" digits — connects 
to 18led edge connector — hivoltage — prime quality 


DVM CHIP 4' DIGIT 


MM5330 — P channel device provides all logic for 47 
digit digital volt meter 16 pin DIP with data $14.95 


NEW ITEM — EXCLUSIVE WITH JEU 


RESISTOR ASSORTMENTS 


SUPPLIED WITH CONVENIENT STORAGE UNIT 
DESIGNED FOR EXPERIMENTERS, TECHNICIANS AND SCHOOLS 


RS 1-25 $99.50 


AN ASSORTMENT OF 
2725 RESISTORS 
170 VALUES FROM 
.51 OHMS TO 5.6M OHMS 
QUANTITIES DETERMINED 
BY TYPICAL USAGE 
va WATT 5% 
CARBON FILM 


+ $1.00 SHIPPING 
& HANDLING 
SHIPPING VIA UPS OR 
PARCEL POST 


REPLACEMENTS IMMEDIATELY 
AVAILABLE AT LOW COST 
BY MAIL FROM IEU 


Rohm 


QUALITY · RELIABILITY 


Red YO 18 

Axial leads 

Jumbo Vis. Red 
(Red Dome) 

Jumbo Vis. Red 
(Clear Dome) 

Infra red diff. dome 
Red 7 seg. .270” 
Red alpha num .32" 
Red 7 seg. .190” 
Green 7 seg. .270" 
-6" high solid seg. 
Red 7 seg. .270" 
Red 7 seg. .127” 
straight pins 

Yellow 7 seg. .270" 
.6" high spaced seg. 
Opto-iso transistor 


MULTIPLE DISPLAYS 


NSN33 Зари .12" red led 12 pin 


fits 1C skt. 


HP45082 5 digit .11 led magn. lens 


7405 com. cath 
HPS082 4 digit .17 LED magn. 
7414 lens comm. cath. 
FNA37 9 digit 7 seg led RH 
dec clr. magn. lens 
SP-425-09 9 digit .25" neon direct 
interface with MOS/LSI, 
180 VDC, 7 seg. 


SHIFT REGISTERS 


MM5013 1024 bit accum. dynamic 


mDIP 


MMS016 500/512 bit dynamic mDIP 


515-4025 QUAD 25 bit 


+, 


29999902070" 
$ Ty 4^ oc 


жузе + 


Й 
i 
$ 


RS 2-25 $114.50 
AN ASSORTMENT OF 


4000 RESISTORS 
100 EACH OF 40 


STANDARD VALUES 
1 OHM TO 3.3M OHM 


14 WATT 5% 
CARBON FILM 


E TT E TD HE 


LE 


?*e699^^50^*^ 


^k 


. 


И 
woe 
ape 

tn RA t 


ФР Орт 


E 


AS APPS 


LEE E 
^5*9929293^^»^* 


* 
злу? 
DORPADPOHR HR 


Lr 


RS 3-50 $69.50 

AN ASSORTMENT OF 
2000 RESISTORS 

50 EACH OF 40 


'› WATT 5% 
CARBON FILM 


MEMORIES 


1101 


256 bit RAM MOS 
1024 bit RAM MOS 
2048 bit static PROM 
UV eras. 

1024 bit static RAM 
2048 bit UV eras PROM 
1024 bit RAM 

1024 bit RAM 

2048 bit RAM 

64 bit ROM TTL 
Programmable ROM 
256 bit RAM tri-state 


CALCULATOR & 
CLOCK CHIPS 


5001 
5002 
129 
$ 5005 
ММ5725 
4 
d ММ5736 
MMS738 
3.25 MM5739 
MM5311 
MM5312 


MMS313 


MMS314 
MM5316 


$1.75 
1.59 
1.29 


12 DIG 4 funct бх dec 
Same as 5001 exc 

btry power 

12 DIG 4 fuct w/mem 
8 DIG 4 funct chain & dec 
18 pin 6 DIG 4 funct 

8 DIG 5 funct K & mem 
9 DIG 4 funct (btry sur) 
28 pin BCD 6 dig mux 
24 pin 1 pps BCD 

4 dig mux 

28 pin 1 pps BCD 

6 dig mux 

24 pin 6 dig mux 

40 pin alarm 4 dig 


STANDARD VALUES 
1 OHM TO 3.3M OHMS 


CLOCK 
CIRCUITS 

5311 $3.95 
5312 2.95 
5314 3.95 


CALCULATOR 
CHIPS 

5001 $1.49 
5002 1.98 
5005 2.49 


Data sheets on request. With order add 
$.30 for items less than $1.00 ea. 


LINEAR CIRCUITS 


Pos V Reg (super 723) TO-5 $71 
Hi Perf Op Amp mDIP TO-5 
Volt follower TO-5 

Neg V Reg TO-5 

Pos V Reg TO-5 Ё 
Op АМР (super 741) mDIP TO-5 . 
Mciro Pwr Op Amp mDIP TO-5 
5V 1A regulator TO-3 

V Follower Op Amp mDIP 

Hi perf V Comp mDIP TO-5 
Hi Speed Dual Comp DIP 

Neg Reg 5.2, 12, 15 TO-3 
Precision Timer DIP 

Quad Op Amp DIP 

Quad Comparator DIP 

Pos V reg (5V, 6V, 8V, 12V, 
15V, 18V, 24V) TO-3 

Pos V reg (5V, 6V, ВУ, 12V, 
15V, 18V, 24V) TO-220 

AF-IF Strip detector DIP 
AM/FM/SSB Strip DIP 

Pos V Reg mDIP 

2w Stereo amp DIP 

2w Audio Amp DIP 

.6w Audio Amp mDIP 

Lo Noise Dual preamp DIP 

Lo Noise Dual preamp DIP 
Prec V Reg DIP 

Timer mDIP 

Dual 555 Timer DIP 

Phase Locked Loop DIP 

Phase Locked Loop DIP 

Phase Locked Loop DIP TO-5 
Function Gen mDIP TO-5 
Tone Decoder mDIP 
Operational AMP TO-5 or DIP 
Hi Speed Volt Comp DIP 

Dual Difference Compar DIP 
V Reg DIP 

Dual Hi Perf Op Amp DIP 
Comp Op Amp mDIP TO-5 
741 Dual Op Amp DIP or TO-5 
freq Adj 741 mDIP 

FM Mulpx Stereo Demod DIP 
FM Mulpx Stereo Demod DIP 
Dual Comp Op Amp mDIP 
Stereo multiplexer DIP 

Dual LM 211 V Comp DIP 
Quad Amplifier DIP 

Core Mem Sense AMPL DIP 
Voltage contr. osc. DIP 

9 DIG Led Cath Drvr DIP 

Dual Line Driver DIP 

Dual Perepheral Driver mDIP 
Dual Peripheral Driver mDIP 
(351) Dual Periph Driver mDIP 
Quad Seq Driver for LED DIP 
Hex Digit driver DIP 


Satisfaction guaranteed. Shipment will be made via first class mail in U.S. 
Canada and Mexico within 3 days from receipt of order. Add $.50 to cover 
shipping and handling for orders under $25.00. Minimum order $5.00. 


California residents add sales tax. 


INTERNATIONAL ELECTRONICS UNLIMITED 
P.O. BOX 1708/ MONTEREY, CA. 93940 USA 
PHONE (408) 659-3171 


the pint size computer that does it all. 
The SRI-1000 Basic is built around National Semicon- 


ductor’s “РАСЕ”. . . опе of the most powerful 16-bit 
processors available. The system includes full keyboard 
control, status panel, 4K ВАМ“, Expandable Prom and 


rear panel connector access. Unit is completely assem- 


bled and tested in a compact, desk-top enclosure. 
“Additional RAM Available 


Options for Above: 

Cassette Interface (Includes 
Tape Program) 

Video Interface (R.F. or Video) 

Modem 

RS-232 Interface 

TTY Interface 

TTL Interface 

Parallel Interface 


BankAmericard) with order to: 
SYSTEMS RESEARCH, INC. 
P.O, Box 151280 
Salt Lake City UT 84115 

! А 801-942-1093 
M^ Miri uc EN Add $ 500 for Postage and Handling. 
Disc) BankAmericard # 

Master Charge # 

Exp. Date 

Signature 


Floppy Disc 

Line Printer 

Tape Reader 

Export Version Available 

Note: All Above are Assembled 
and Tested. 


9080 Microproc 

Replaces 8080 

91L02 1K low power RAM 

2102 1k RAM 

ASCII Keyboard Kit... А 
FEATURES: Full 55 key, reliable scanning logic, № 
key rollover, TTL compatible parallel output. Also 
available-serial output, parity bit, TTY current loop 


ж 
Other 
kits available: 


1702 PROM Programmer 125.00 
8223 PROM Programmer 79.50 
Audio cassette interface 69.50 
CRT TV display 


Write for information on our INTELLIGENT TERMINAL 
and other computer products 


MIKRA-D 


Inc., 
P.O. Box 403, 
Holliston MA 01746 
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Send Cash or Check (MasterCharge or | 


compilers, stack, assembler, 
mnemonic, opcodes, 
disavowal. 


A uP could be used as the 
heart of an automatic 
bowling scorer, getting pinfall 
data, machine position data, 
bowler ID data and special 
information for error 
correction — and in turn 
would control the printer (or 
TV display) error correction 
display, etc. I have special 
interest in such a machine! A 
machine exists, implemented 
with IC logic — but what 
power has a uP?? 
Programming the uP must 
come after a good knowledge 
of its inner workings and a 
good mental model is 
developed. 

I hope BYTE magazine 
will try to get to the basics of 
computing using the uP. What 
jobs are they fitted to? Could 
an 8080 be used for: 

1. A complex pin-ball 
machine control? 

2. A computer like HP-65? 

3. Bowling computer? 

4. Automatic machine 
controls — various. 

I hope your magazine will 

direct some effort towards 

people with needs and 
interests like mine. 

Pat Murphy 

Muskegon MI 


You should be 
straightened out on the 
circulation error by now, Pat. 
We've had some articles on 
basics to date, and will 
continue to do so in future 
issues. 


LOGICAL 
COMPLEMENT 


Dear Mr. Helmers, 


I was struck by your 
editorial in the October 1975 
issue, “The Home Brew 
Voder," because I have long 
wanted to be able to use a 
small computer for exactly 
the opposite purpose. I want 
to be able to speak into a 
microphone and have an 
electric typewriter type out 
the words I am saying. 

I am a writer and, speaking 
as a writer, it has always been 
the most tedious (if 
necessary) chore when 


researching material to have 
to copy out my source 
material by hand, to make 
notes by hand, and then to 
rewrite my first drafts by 
hand (and by “hand” ] mean 
by typewriter also). It would 
be much easier and more 
accurate when researching 
source material especially to 
be able to read the material 
out loud and have an accurate 
typescript made 
automatically, or, what 
amounts to the same thing, to 
read the material into a tape 
recorder for later 
transcription ... 

... If you or any of your 
readers can convert this idea 
of mine into practical 
circuits, I would certainly 
appreciate it, and [ am sure 
the idea is commercially 
viable as well. 

М. Krieger 
37 Eighth Ave. 
Brooklyn NY 11217 


THE AUDIO CASSETTE 
TOWER OF BABEL 


Dear Mr. Helmers, 


Congratulations! I am glad 
to see a real magazine 
exclusively devoted to the 
"do it yourself" computer 
enthusiast — now I don't have 
to buy an audio or electronic 
magazine for one article 
about computers. 

You are right about the 
three areas to cover — 
hardware, software and 
applications. However, there 
is another area that ties these 
three together and without it 
we would have chaos — that 
area is standards! 


Now that so many 
manufacturers are getting 
into tne computer field 


everyone wants to do their 
own thing. That’s fine — but, 
we do need standards. It is 
not really important what 
goes on in the “‘black box" or 
how fancy the operating 
system is as long as we can 
swap programs and they will 
run without having to rewrite 
them. 

As the first magazine in 
the field, you can be the 
driving force in helping to 
prevent a “Tower of Babel." 
We need a specification 
spread sheet so that 


JAMES CHRISTMAS SPECIALS 


DIODES TTL/LINEAR CLOCK & CALC. CHIPS 
SOV Ө 1 Amp Gate MMS3MIN. & Digit $295 
100V 1 Amp Decoder MMSIZN 4-Digit 295 
200V @ 1 Amp Counter К MM5313N. 650 2.95 
400V Ө 1 Amp 8 Ви Latch 99 MM534N GÜg 235 
Switching 24354 Decoder E MM5316N 5 Dpt Alum 3.95 
M19] Counter 25 ММ5725№ 8 Оид fum. 135 

TRANSISTORS LM30IH ~LM241H A/$1.00 MMSTAON. Ha Pum 195 
2N2907A PNP Switching — G/S1.00 LM324N- Quad 741 118 MM5738N hgi-b Funk. 296 
2N2222A NPN Swatching GS1.09 — LM3O9H ЗУ Reg 105 79 26 Awg RIBBON CABLE 

2N3904. NPN Amp estoa 1М209К SV Reg ТОЗ 39 Trt Risin 199. ИТ 
2N3906 PNP Amp 6:51 00 “бөй Bhk 25. 


2М818 NPN AF рш ММ5262 DYNAMIC все E 


B Cond. 49 н. 
295851 Nd Fet 651.00 2К ВАМ $2.95 


16 Cond. юн. 
C10681 36AmpSCR 2/51 00 32 Cond. 1,69 К. 


MICROPROCESSOR COMPONENTS 


ло - $2.95 


ae 


5974009 
SN7401N 
SN7402N 
SN1403N 
SN7404N 
SN7405N 
SN7406N 
SN7407N 
SN7408N 
‘SN7408N 
SN74V0N 
SNH TIN 
SN2412N 
SN1413N 
SN7414N 
$N1416N 
SNT41IN 
SN)418N 
SN1420N 
SN7421N 
SN1423N 
SN2428N 
SN426N 
SN1427N 


7400NTTL 49 


SN7451N 5М741514 
5М745304 SN74155N 
SN7454N SN74154N 
SN7458A SN74155N 
SN?7460N SN74156N 
$N1470N SN74157N 
SN1472N SN74160N 
SN7473N SNIATGIN 
SN7474N SN74163N 
SN7475N SN74164N 
SN7476N SN74165N 
SN7480N SN74166N 
SN1482N SNI4167N 
SN7483N SN74170N 
SN74B5N SN14172N 
SNT486N SN74173N 
SN7488N $N74174N 
SN7489N SN14175N 
SN7490N 5874176N 
SN7481N SN74172N 
SN7492N SN74180N 
§N7493N SN74181N 
SN7494N SNT4182N 
SN7495N SN74184N 


вов - $19.95 


8008 
8080 
4040 


194001 
1м002 
104003 
1N4004 
14148 


15/5100 
185100 
19°51 00 
1$'$100 
205100 


1400 
144! 
7490 
14100 


115100 
a сиз 
Ewe CPU $1955 
Вън Super 8066 14995 
4 tnt 8080 39.95 
VARTS 
AY- 5- 1013 
PROM'S 
8223 
NDA 


$2030 
745267 


3218 Prom. 
2K E Prom 
IKE Prom 
IK» Prom 
SR'S 


zan 
2533 


91L02 


Vector General Purpose Logic CARD Board 14.95 
"Very High Noise Immunity. * Holds 32 ва. 14 pin DIPS 
*44 pin Edge Connection 


THE KILOBYTE RAM CARD PerKit — $49.95 
*Complete 1Kx8 Memory * High Noise immunity Components. 
*Single Sv supply *500NS Access Time &Kit includes sockets, ICS & 


. 2K DSR 
1! C IK SSA 
УК Siale RAM Duect Replacement dur 2102 1 
with 40% Less Current Ürawn. 


SN7429N 
SN7430N 
574320 
SN7A3IN 
SN7438N 
SN7439A 
SN2440N 
SN7A41N 
SN7442N 
SN1443N 
574440 
SN7445N 
SN7446N 
SNI4AIN 
SN1448N 
SNI480N 


с04000 
CD4001 
CD4002 
CD4008 
C04007 
CD4008 
coda 
coal 
с04012 
С0а013 
Coane 
CD4017 
604019 
с04020 
CD4022 
CU4023 
CD4024 
С04025 
codo7? 
CD4028 
tnao28 


SNT495N 

SN74100N 
SN14107N 
SN121N 
SN74122N 
SN74122N 
SN74125N 
§N74126N 
SN74132N 
SN24M1N 
SN 24142N 
SN74143N 
SN74144N 
SN74145N 
SN74148N 
SN74150N 


£04050 
С04051 
04063 
cp4060 
С04066 
с04069 
CD4071 
0408) 
74COON 
JACO2N 
TaCOAN 


SN74185N 
SN14187N 
SN74190N 
SN74 19 1N 
SN74192N 
5241930 
SN74194N 
SN?4195N 
SN174196N 
SN?4197N 
SN?4198N 
SN74199N 
SN14200N 
SN74251N 
SN74284N 
SN74285N 


сїн 
7AC20N 
TC30N 
MCA2N 
TC73N 
men 
14С90М 
74C95N 
741076 
REISI 
aC ibd 
740157 
ciet 
14С161 
740163 
nct 
140173 
240193 
740195 
80С97 


GENERAL DESCRIPTION 


The ЈЕВОТ is a three and one half digit, auto 
polarity digital voltmeter, in a kit form. It 
features several options not available in any 
commercial digital voltmeter. Its low cost is 
perhaps the most important feature, which is 
achieved by offering it in a kit form. A kit 
allows the unit to be used by small OEM's 
where cost effectivenessis an important factor, 


$39.99 Per Kit 


SINGLE UNIT 


and by the hobbyist who has to be concerned. 
with cost. The unit also features on card 
regulators, allowing it to be operated off a 
single plus and minus fifteen volt, unregulated 
power supply. The unit has à small size of 
three inches width, three and three quarters 
of an inch length, and one and a quarter inch 
height. 


Board 


XR-2206KA 


instruct 


ion manual. 


XR-2206KB 


XR-2556CP 
XR-2240CP SPECIAL 


PHASE LOCKED LOOPS 
XR-210 

XR-215 

XR-567CP. 


XR-2587CP SPECIAL 


nonn 


CA3130 
MCMOBL? 
F334) 


Dual Trach V eg 
215V Track Rog 
Decoder 

DVM Chip Set 


$ 69 
1.55 
1.85 
3.20 
3.25 


5.20 
6.60 
1.95 


$995 


Super CMOS Op Amp 


ND 
FIFO 


4 PDT SWITCHES, 
HIGH QUALITY 
P B. TYPES .69 


SPECIAL $17.95 


Includes monalithic function generator IC, PC board, and assembly 


SPECIAL $27.95 


Same as XR-2206KA above and includes external components 
for PC board, 


TIMERS 

XR-555CP SPECIAL 
XR-320P 

XR-556CP 


STEREO DECODERS 
XA-1310P 
XR-1310EP 3. 


$3.20 


20 


XR-1800P 3.20 


WAVEFORM GENERATORS 
XR-205 

XR-2206CP SPECIAL 
ХА-2207СР 


MISCELLANEOUS 
XR-2211CP 
XR-2261 


N8797 $3.00 
Ae 225 
2513 
2510 
2524 
2526 
2527 


2533 
8263 
8257 
8288 
8826 
8880 


500 


ZENERS-DIODES-RECTIFIERS 


TYPE 

1N4003 
144008 
1N3600 
INA 148 
IN4154 
1№734 
184735 
184736 
1N4738 
IN4742 
144744 
1183 
INTISA 


LMI310N 1497 
LMI351N 
LM1414N 
1М1458С 
CM 1496N 
LM1556V 
LM21TUN 
LM2301N 
LM3065N 
1M3300N 
LM3905N 
LM5556N 
MC5558V 
1M7525N 
LM7528N 
LM7534N 
LM7535N 
80388 
м75450 
75451CN 
T5452CN 
75483CN 
T5454CN. 
T5491CN 
T5492CN 
75494CN 
RCA LINEAR. 
CA3013 170 
CA3023 
CA3035 
CA3039 
CA3046 
CA3059 
CA3060 
CA3080 
САЗОВЗ 
CA3086 
CA3089 
CA3081 


LM100H 
LMTUDH 
мин 3175 
LM212H 700 
LM3DUM 80 
LM301H 3100 
AM3QICN 3/100 
1M302H 75 LM382N 17/9 
LIA304H 100 NESOIK 800 
1м305н 95 NES10A 
LM307CN 35 NES3IH 

1M3UBH 100 NE536T 
LM30BEN 100 NES40L 

LM309H — 110 NESSON 
(M309K 125 МЕБ53 

LMSIUCN 115 NESSSV 
[EHI 9n NE565H 

IM3IIN 90 NE565N 
(MIIBCN 550 NESBSCN 

LM HIN 130 NE5G2H 
1M319D 900 NES67V 
1MIMUKS 135 LM703CN 
1м320к 8.2 135 LM709H 
LMJZOK 12 1 Sh LM709N 
LM320K 16 135 LM710N 

1M323K 5 10.50 мин 
1м324м 180 LM723N 
14339N 170 LM723H 
1М340К 5 195 LM?33N 
UM340K 12 135 L739N 

LM340K 15 195 LMI4ICH 3/100 
1M340K 24 195 LMJAICN 3:1 00 
UMa40Tu 175 M741 14N 
LMI 6 4,76 (муан 
LM3AUTo 12 175 мат 
Ммз401о 151 75 LM7238H 
1м34010 24 1 75 ЧАТЕ] 

1 м350% 100 LN1303N 
LMILICN 65 LM1302N 
LM370N 115 LMI1305N СА3123 
\мїїїн 115 1M1307N CA3600 


DATA HANDBOOKS 


Pin-out & Description of 5400/7400 ICS $2.95 к 
Pin-out & Description of 4000 Series ICS $2.95 | досу. 5 Sen: 56K 
Pin-out & Functional Description of 150K — 180K 


TP LINEAR 
LM373N 325 
LM377N 400 
LM380N 139 
LM380CN 105 
LM381N 1n 


DISPLAY LEDS 


Com. Cath. 
Com. Апа, 
6х7 Matrix 


DISCRETE LEDS 


Mv 10 
МУ 50 
Mv 5024 
му 5024 
Mv 5024 
MV 5024 
Mv 50° 


ЕМ070 
MAN 1 
MAN 2 
MAN 3 
MAN 4 
MAN 1 
0133 

DL747 


TYPE 
IN746 
IN751A 
IN752 
19753 
1754 
IN9658 
185232 
1N5234 
1N5235 
1IN5236 
IN456 
IN458 


vOLTS w 
400m 
400m 
400m 
400m 
400m 
400m 
500m 
500m 
500m 
500m 
40m 

150 7m 

IN485A 180 10m 

tN4001 50PIV 1AMP 

1N4002 100 PIV 1 АМР 


MPS А05 5100 
МР5 А06 55100 
2N2219A 35100 
282221 45100 
2N2222A 55100 
2N2368 5/5100 
2N2369A 4/5100 
FN2415 515100 
792484 451 00 
2N2906A 115100 
2N7907A 6/51 00 
1828925 5$1 00 
2N3053 2/8100 
2043055 $89 

14 PCS. POTENTIOMETER MJE3055 5,69 
ASSORTMENTS $9.95 243482 anm 
Each assortment contains 14 pcs of 10 turn pots. 


ASST.A 2«: 10 0HM-20 OHM-50 OHM-160 OHM 
200 OHM-250 OHM-500 OHM 


ASST.B Zea: IK, 2K, 2.5K, 10K, 20K, 25K, 50K 
ASST.C 29: Pus 100K, 200K, 250K, 500K, 1M, 
M 


PRICE 
оа 
4/100 


VOLTS W PRICE 
200 РІУ 1 АМР 10 
400 РІУ 1 АМР 10 
200m 6/1 00 

10m 15/1 00 

Толь 1271 00 


59 
НМ 51.85 
300 395 
Com. Cath. 125 38 
Com. Cath. -187 1.95 
Com. Ano. 30 1.50 
Com. Cath. .425 1.98 
Com. Ano. 525 1.95 


1С SOLDERTAIL — LOW PROFILE (TIN) SOCKETS 


Hed 

Red 

Red 

Green. 

Yeliaw 
Orange. 

Red 1%" Leads 


5 5100 
55700 
5100 
4,5100 
4151.00 
95100 


24 ри 
28 па 
36 ре 
40 pin 


Saw 
Maw 
16 pn 
Vow 
77 om 


100 PIV 
INTIBG 200 PIV 
191188 400 PIV 


TRANSISTORS 
РМ3567 } 
PN3S68 
PRISED 
2n3700 
2N3705 
23700 
2N3707 
280m 
2м3724 
293225 
2N3903 
2N3904 
2N3805 
13908 
204013 
pom 


SOLDERTAIL STANDARD (GOLD) 
ёр 1 м 74 pin 
M gin P 32 29 28 pn 
16pm 35 32 36 pin 155 
18 pm 41 43 40 pin 1/5 


WIRE WRAP SOCKETS (GOLD) LEVEL «3 
(Don X 41 з 24р $105 
Van 38 3 2B pn 140 
16 pin E 42 41 36 ра 158 
18pm E 5% 62 40 pn 175 


5 0 
110 


50 PCS. RESISTOR ASSORTMENTS $1.75 per assort. 
Each assortmant contains 50 pes. af % watt, 5% resistors 
то OHM- 32 OHM. 15 OHM- 18 OHM. 22 OHM 
ASST. 1 бөк 27 OHM- 33 OHM- 39 OHM- 47 OHM- 56 OHM 
ASST.2 Son: 68 OHM- 82 OHM-100 OHM-120-0HM-150 OHM 
Е * 180 OHM-220 OHM 270 OHM-330 OHM-390 OHM 
470 OHM- se а € OMA OHM IK 
ASST.3 Sea: 1.2K 2K 2.7K 
3.3K 
ASST. 4 Gea: 8.2K 


CAPACITOR CORNER 
50 VOLT CERAMIC DISC CAPACITORS 


1049 50-100 
«м 3 
All pots aca avaituble in single unit quantities, $.99 ea. 


DPST С& К ROCKER SWITCH 
Thay are rated at 125 Vac Ө БА. 
They are excellent in application 100 VOLT MYLAR FILM CAPAC HIG 
such as Microcomputer 4 . В 2 fmt 43 
Panel Switches 07 Domo 


$0.69 i : : ‘07 им 27 


Linear Circuits — $2.95 | ASST.6 Sea: 390K — 470K 
Dim: 1"x1"x X" И : 10 07 2m 33 


м 012 

6’ POWER SUPPLY CORDS.. ASST 7 &w.27M — 33M 

P 2 CONDUCTORS SPECIAL ЖЕТ, 20% ра TANTALUMS (SOLID) CAPACITORS 
3/$1.00 | PRIME Ant peor Ma no sum 55.55 ASST. 15 ЗБУ 28 


THUMBWHEEL SWITCHES Pe re a Mme Hem owen | BEF 


CIRCUIT SN MS Mi 24151 33 35V 28 
$ Кыса ак. 
t кж pun 


47 35у 28 
слабо! Ap 4012 68 35V 28 
ASSORTMENTS C04016 409 4023 
Soap together - Мо Magoma 
Ин From Monat Алты 11 И 


к 
10K 
к 
68K 


hy 
12K 
33K 
82K 
220K 
560K 
1.5M 
3.9M 


н 
15K 
39K 
100K 
270K 
680K 
1.8M 
лм 


6.8K 
18K 
атк 
120K 
330K 
820K 
2.2M 
5.8M 


7400 
CMOS 
LINEAR 


MSUTTL 


ASST 10 CMAS 5798 ASST 


10 35v 28 
LM3DIT 2027 3071 
MINIATURE ALUMINUM ELECTROLYTIC CAPACITORS 
nut LL BIN LL Anal Leni Radial Lead 
1 : 


ASST 11 LINEAR $10.95 ASST 


Satisfaction Guaranteed. $5.00 Min. Order. U.S. Funds. 
California Residents — Add 6% Sales Tax 


Write for FREE 1976 Catalog — Data Sheets .25¢ each 


“GAMES 


OX 822, BELMONT, CA. 94002 
PHONE ORDERS — (415) 592-8097 


Orden: Orán Osod amich or телна and add nscraery scormocas (ы yout 
рткы орамат 
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PAPER TAPE READER 


“fly 
reader 30 


ONLY 
$295 
(kit) 


TELETERMINAL 


DIRECTLY COMPATIBLE WITH ALTAIR 
8800 PARALLEL INTERFACE BOARD 


FEATURES: 


O to 300 character per second bi-directional 
reading speeds. 


e Single 5 volt, 2 amp power requirement. 

€ Reads any one inch, 8 level paper tape. 

e Reads any tape material with less than 6096 
transmissivity (oiled yellow paper). 

ө Stepper motor drive - one moving part. 

ө Spring loaded line filament lamp with 
15,000 hour life. 

€ Self-cleaning read head. 

ө TTL interface, mates with most micro 
computers. 

e Mounts in 4-3/8"H x 4-1/4"W panel cutout 
extends 2-1/2" behind and in front of 
the panel. 

PRICES: 

e Fly Reader 30 Kit (only main PC | $295 
board requires assembly) 

e Fly Reader 30 (assembled and tested) $365 

ө Optional fan fold trays (200' 
capacity) mounted on 19"Wx7''H 
rack panel $110 

€ Optional 19'"Wxb-1/4"H rack panel 
mounting $ 25 

ө Optional 5/8 level tape gate for 
reading both 5 and 8 level tapes $ 25 

TERMS: 


e Net 30 days for rated firms. 
ө Cash with order or master charge plus $3 


shipping for individuals within continental 
U.S.A. 


12 CAMBRIDGE STREET 
BURLINGTON, MASSACHUSETTS 01803 


617/272-8504 


TELETERMINAL CORPORATION 


С] 


comparison can be made. For 
example, Popular Electronics 
came out with their HIT 
cassette interface, the 
Computer Hobbyist has 
another, the Southern 
California Computer Society 
has one and so does MITS. I 
understand that the Digital 
Group in Denver has a tape 
transport. Which is best? 

Can I run MITS BASIC in 
any other mini? Does anyone 
make a mini [ can run 
Datapoint software in? 

I realize that this is quite 
an undertaking but think of 
the thousands of hours that 
will be saved if this 
information is available. You 
have made a good start with 
“Which Microprocessor for 
You?” 

As you probably guessed I 
am an application man and 
over the years have developed 
quite a Fortran subroutine 
library. This makes it easy to 
write a program — just call, 
call, call! I hope to provide 
some useful articles later after 
I get my Altair up to being a 
workhorse instead of just a 
toy. 


William D. Roch 
Woodland Hills CA 


ON LIFE 
AND 
LIFELINE 


Dear Sirs: 


The first issue of BYTE is 
excellent. BYTE looks as if it 
is going to be exactly what 
(in my opinion at least) a 
computer hobbyist magazine 
ought to be. 

Just one slight correction; 
the inventor of the game of 
LIFE is John Horton 
Conway, a professor of 
mathematics at Cambridge 
University (England), not 
Charles Conway as reported. 
LIFE was first widely 
publicized in the October 
1970 issue of Scientific 
American and according to 
Martin Gardner in the 
November 1971 issue of that 
periodical (page 121), a 
newsletter called LIFELINE 
was started in 1971 by 
Robert T. Wainright, 1280 
Еасгіѕ Rd., Yorktown 
Heights NY 10598. However, 
I never subscribed to the 


newsletter and have no idea 
whether it is still going or 
not. Perhaps one of your 
other readers will be more 

informative .. . 
Charles A. Dunning Jr. 
Sterling Heights MI 


1 AND 1 
EQUALS 2? 
BYTE: 
An article in issue #2 


prompts me to write about 
something: Have just started 
reading up on computers and 
associated equipment. One 
item I read was about AND 
gates and OR gates, and their 
logic. In my opinion they are 
designated incorrectly. 
Remember in grade school, 
when you had the arithmetic 
problem 1+1 = 22 

Most of us said *1 and 1 
equals 2." In other words the 
+ sign (plus sign) stood for 
and. 

Now in Boolean logic they 
say that the + sign means OR. 
And the * means AND. 

Would have been much 
better to have the + sign 
mean AND, and the • sign 
mean OR (the * sign looks 
more like the 0 or OR filled 
in than a plus sign), but it's 
too late to change this 
system, because it's been in 
use too long. 

But maybe it's not too late 
to change the system used on 
page 43 of issue #2 of BYTE. 
This shows LED bit pattern: 
0-LED on; 6-LED off. To me, 
the filled in zero looks more 
like an LED that is on, and it 
seems a better illustration 
would be: 6-LED on; 0-LED 
off. 

The ASCII code for A 
would then look like this: 6 
000 008 with the filled-in 
circles indicating the punched 
out holes. 

BYTE looks great. Keep it 
up! 

James C. Madsen 
Fresno CA 


The AND function is 
"logical product," the OR 
function is “logical sum." 
The symbols are of course 
merely the usual product and 
sum symbols of mathematics. 
The way it is said in grade 
school is colloquial but, 
unfortunately, not true. 


THE SUNTRONIX MODEL KBD IV Keyboard is ideally suited as a general 
purpose ASCII Keyboard for data terminal applications. This keyboard more than 
meets the needs of the data entry market for long life and reliability. 


The KBD IV utilizes the 2 key rollover solid state read-only MOS memory allowing 
encoded outputs to be strobed out as each key is depressed. A second key may be 
depressed concurrent with the first, but the second key encoded output will not be 
strobed out until the first key is released. This feature prevents ambiguity of 
character codes as a result of two keys being depressed in rapid succession. 


ELECTRICAL SPECIFICATIONS: 

* Voltage requirements — +5.0 V and —12.0 V 

* Power consumption — less than 200 mw 

* Outputs — standard ASCII; 8-bits + strobe 

* Negative or positive logic output, jumper selectable 
* Output connector — standard 14 pin DIP IC socket 


MECHANICAL FEATURES: 

* Size — 12%" x 6%" x 2%" 

* High grade glass epoxy PC board 

* Keyboard ROM SMC KR2376 40 pin MOS 

* Electronic shift lock, not mechanical 

* Keyswitches one integral assembly, not individual keys 

* Switches have four-finger phosphor bronze contacts with gold inlay 
* Keycaps are 2-shot high strength ABS plastic 


These keyboards are available off the shelf in two forms — fully assembled and 
unconditionally warranteed against defects in manufacture or materials for a full 
ninety days, or in the more economical kit version. Kit parts are fully warranteed 
against defects in manufacture or materials for a full ninety days. In either version, 
full instructions are supplied for operation, including specifications and data sheets. 
In the kit version, complete instructions are supplied for the assembly process. A 
reasonably competent technician can completely assemble and test this keyboard in 
one evening. Ali parts needed are included. f 


INTRODUCTORY PRICES 


Factory assembled — $59.95 ppd. 
Complete kit, w/instructions — $54.95 ppd. 
Please add $1.00 handling per order. 
Minimum order — $5.00 


Bl [I]; 01 4 COMPANY - 


6 KING RICHARD DRIVE, LONDONDERRY, N.H. 03053 
603-434-4644 


REVIEWS 


The Bugbook 11: Micro 
Computer Interfacing by 
David G. Larsen, Peter R. 
Rony and Jonathan A, Titus. 
Published by E & L 
Instruments, Inc., 61 First 
St, Derby CT 06478; 
1-203-735-8774. $14.95. 


This excellent book is 
highly recommended to all 
microcomputer 
experimenters, and is a 
"must" for 8080 users. It 
includes probably the best 
available tutorial discussion 
of hardware and software 
techniques for  interfacing 
microprocessors to external 
devices, enabling them to act 
as device controllers ог 
sequencers. It also includes an 
excellent introduction to 
programming concepts and 
the 8080 instruction set, and 
a very good discussion of 
interrupt handling. 

Bugbook 111 is the fourth 
in a series of books prepared 
by the authors to teach the 
application of modern digital 
electronics to the control and 
monitoring of physical 
processes. Bugbooks І and // 
describe experiments with 
conventional TTL integrated 
circuits, while Bugbook IIA 
deals with asynchronous data 
communications using 
UARTs. Each of the 
Bugbooks describes 
experiments which are to be 
performed with the Micro 
Designer  student-oriented 
interfacing system and the 
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Mark 80 microcomputer, 
which are marketed by E & L 


Instruments, Inc. Authors 
Larsen and Rony аге 
associated with Virginia 
Polytechnic Institute and 


State University, where they 
teach both regular and 
extension courses on digital 
electronics. 

Bugbook lll is organized 
into eight instructional units. 
Each unit begins with an 
introduction, a list of 
objectives, a glossary of 
definitions, and ends with a 
set of experiments, a test, and 
a review section which relates 
the material just covered to 
the initial list of objectives. 


Unit 1 provides a general 
introduction and orientation 
to computers and 
microprocessors, discusses the 
basic tasks of interfacing a 
microprocessor to the outside 
world, and summarizes the 
characteristics of the 8080 
microproccesor. Unit 2 
describes breadboarding 
techniques specific to the 
Mark 80 microcomputer 
system. Unit 3 introduces the 
basic concepts of stored 
programs, instructions, and 
machine language, explains 
how instructions are decoded, 
and summarizes the 8080 
instruction set in various 
ways. 

Unit 4 describes ways of 
generating device select pulses 


to signal one of several 
input/output devices, and 
relates the 38080's 


input/output instructions to 
the device selection signals on 
the address lines. Unit 5 
explains how microprocessor 
programs and timing loops 
can be used to provide time 
delays and sequencing for 
external control. Unit 6 is a 
lion-hearted attempt to 
clarify the complex details of 
decoding the 8080's external 
status signals in order to 
identify specific machine 
cycles which are entered as 
each instruction is executed. 

Unit 7 further develops 
the techniques for 
input/output, and describes 


how the Mark 80 bus signals 
and control lines may be 
monitored (the Mark 80 ‘is 
especially well designed for 
this purpose). Unit 8 
discusses subroutines, 
interrupts, external flags and 
stacks, and includes a good 
introduction to the possible 
ways of dealing with 
interrupts. 

The authors have done a 
really excellent job in several 
areas. One area is the 
definition of terms: Each unit 
begins with a glossary of 
definitions, and many 
definitions are repeated for 
emphasis in the context of 
the discussion in the text. 
Another area is the 
organization of the text for 
instructional purposes and 
the effort to provide 
motivation for the student. 
Still another area where the 


book succeeds is in the 
relation of hardware 
functions to software 
concepts. 


The material on the use of 
software timing loops and 
their use in sequencing and 
controlling external devices is 
difficult to find elsewhere. 
The discussion of interrupts 
covers the essential concepts 
of saving status information, 
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enabling and disabling the 
interrupt system, and 
choosing among interrupts of 
different priorities. 


The book does a good job 
of introducing basic 
programming concepts, and 
provides a large number of 
programming exercises which 
explore the 8080 instruction 
set in some depth. However, 
this Bugbook does not cover 
“higher-level? software 
concepts beyond the idea of 
simple loops and subroutines. 
All of the examples are 
presented in absolute 
machine language, and the 
use of assembly language is 
mentioned only briefly. 
There is no coverage of 
higher-level languages or of 
software ‘‘multi-tasking” 
approaches to the handling of 
multiple 1/O devices and data 
streams. Perhaps these topics 


will be covered in another 
Bugbook. 

This book fills an 
important gap їп the 


currently available literature 
on microcomputers: It deals 
squarely with the 
interrelationships of hardware 
and software at the level of 
input/output device 
interfacing. This is in line 
with the authors' view of the 
role of microprocessors as 
device controllers rather than 
as general purpose computers. 
Readers who intend to 
connect their home computer 
system to their ham radio 
gear, model train system, 
electric range, burglar alarm 
system, or whatever, would 
do well to obtain this book. 
Any 8080 user who is a 
hardware or software hacker 
and is having trouble 
understanding the jargon of 
the “other side” would also 
profit from this book. The 
experiments depend to some 
degree on the layout of the 
Mark 80 system, but the text 
(with the exception of Unit 
2) is applicable to all 8080 
systems. For instructional 
purposes, this book is one of 
the best available on the 
market today. --d.h.f. 


Bugbook, Micro Designer and 
Mark 80 are trademarks of E & L 
Instruments, Inc. 


KEYBOARD KIT KEYTOPS & SWITCHES 
TO MAKE YOUR OWN KEYBOARD 


This very unusual key- 

board kit is made by Micro 

Switch. It has a set of 

switches & space bar in a 

t modular frame, plus 42 

molded double-shot keys in red, white, or blue. There are 8 control 
keys in addition to letters, numbers, & many symbols. The switches We have a large selection of KEY TOPS and SWITCHES, made by 
are arranged in 4 rows, but are easily removed or moved to other RAYTHEON CO. The keytops come in black, grey and white, 
positions. This makes for a very versatile keyboard, since any number with contrasting legends. The switches mate with the tops, and are 
and type of key can be arranged in any pattern to suit your own needs. magnetic reed switches. The following combinations are available: 


Any type of encoding can be wired. Finished size is 9%” x 3%” x 2”. 54 key typewriter set, keys only, black K9276 2.95 
54 key typewriter set, keys only, grey K9278 2.95 


STOCK NO. B6015 Keyboard Kit 2% Ibs. $19.95 ea, 2/35.00 54 key TTY set, no symbols white K9279 2.95 
54 key TTY set, with symbols white K9282 2.95 


VOLTAGE REGULATORS 54 key set, keys & switches black K9288 30.00 
54 key set, keys & switches grey K9290 30.00 
54 TTY set, no symbols keys & Sw, White K9291 30.00 
54 TTY set, with symbols, keys & Sw. whiteK9291 30.00 


Key Numeric set. Keys only Black K9283 1.50 
Key Numeric set, Keys only Grey K9284 1.50 
Key Numeric set, Keys only White K9295 1.50 
Key numeric set, Keys only white K9286 1.50 


B9013 
Key Num.set, keys & switches Black K9293 7.00 


Key Num. set, keys & switchesGrey K9294 7.00 
B5169 is a board containing 3 15 volt high current regulators Key Num. set, keys & switchesWhite K9295 7.00 
with 0.1% regulation. 2 of the regulators are rated © 3 Amps., Key Num. set, keys & switcheswhite K9296 7.50 
and the other @ 6.0 amps. The current in each regulator may 4 А ; 
be doubled with the regulation going to 0.576. All З regulators Brank Key 2 keys 1де white К9297А 3/.25 
are short circuit proof, anz 2 have electronic crowbar protect- K9297A with switch white K9298A 3/2.00 
ion. Brand new, in factory boxes. With data. К9297В with switch white K9298B 3/2.00 


STOCK NO.B5169 $11.95 ea. 2/21.00 TRANSFORMERS 


B9013 is a triple regulator with +12 volt regulation © 200 ma., Cuinputer projects need power supplies. Finding the right power 


and the third regulator is a tracking regulator. It may be set transformer сап be a problem. We have one of the largest and 
between 0 and 5 volts @ 500 ma. With data. most diversified stocks of power transformers in the country. 


Below we list some representative items in our inventory. Our 

STOCK NO. B9013 $5.95 each, 2/10.00 catalog, free on request lists many more. 
B4481 is a VOLTAGE REGULATOR IC, type M1568. It is 36 V. вот О A. ct, & 6.3 V @ 200 ma. З Ibs. B9313 3.50 2/6.00 
designed to provide balanced * and — output voltages at currents 20 M » 19 ^ ct, M $3 M o 500 ma. SP 89314 5.50 2712.00 
to 100 ma. each. It is set internally for +15 volts but тау be 20 VE 2AA ct, VETS A. ^s |b. . ` 
- - 50 М. @1.5 A. ct, & 6.3V (9500 ma. 6 Ib. B9316 6.50 2/12.00 
externally adjusted between 8 and 20 volts (tracking). Packaged 26 V.& 1.0 A. ct. 663 V. @ 500 ma. 3 Ib. 89318 3.75 2/7 00 
in a 14 pin plastic DIP. With data. 38 V. & 1.5 A. ct. & 6.0 V.@ 500 ma. 2 ib. B9319 6.95 2/13.00 
STOCK NO. B4481 +15 volt regulator DIP $1.50 ea, 4/5.00 | 350 у. @ 35 ma. ct. & 6.3 V. 8 2.7 A 2 Ib. B9321 3.50 2/6.00 

70 V. € 1.5 A. ct. & 6.3 V © 1.5 A. 7Lb. B9322 6.75 2/13.00 

COMPUTER DATA INPUT KEYBOARDS 35 V. @ 6.0 Ct. & 10 V. @ 10.0 A. 6.0 Lb. 89906 8.95 еа. 


64 ог 32 V. € 8.0 A. ct. & 18 V. € 8.0 A ct. 10 Ib. B9905 11.95 


COMPUTER GRADE ELECTROLYTICS 


We carry a good selection of capacitors of all types, dipped micas, 
ceramic disks, mica trimmers, tantalums, silvered micas, tubulars, 
small electrolytics, high voltage, etc. Listed below are a few of our 
large computer grade electrolytic capacitors. 

VOLT MFD STOCK PRICE 


10v 40,000 B2026  2.00each,  6/11.00 
10v 90,000 B2495  3.00each,  3/8.00 
MEYTYSSRES3BENE 10v 160,000 B2515 3.25 еасһ  4/12.00 
i Pewee FP | 15v 110,000 B2352  3.50each,  3/9.00 
25v 32,000  B2492  3.00each,  4/10.00 
3bv 40,000  B2255  3.50each,  3/9.00 
50v 10,000 82493 3.25 еасһ  4/12.00 
75v 6,000 B2450 3.50 еасһ,  4/12.00 


А a 200v 500 B2345 2.50each,  4/9.00 
ASCII encoded keyboard. In its own enclosure. Originaly used in 


SANDERS ASSOCIATES 720 Terminal System. In like new OP AMPS 
condition. Usefull for any project requiring an ASCII encoded . 
keyboard. 50 Alpha Numeric keys plus 11 computer symbols DESCRIPTION CASE STOCK PRICE 


STOCK NO.B5283 keyboard $35.00 2/65.00 Hi Performance ТО-5 B4301 -50 5/2.00 
Dual 709 DIP 85301 1.00 6/5.00 


nhau Hi Performance DIP B4316 . 5/3.00 
— . k 
MICRO-SWITCH (Honeywell) 8 bit binary coded board. 56 keys, Dual 741 DIP 84317 . 5/5.00 


alpha -meric and computer symbols Built in TTL decoder. New Hi Performance Mini DIP B4345 | 5/3.00 
in factory cartons. eautifu yboard. Dual 741 TO-5 83111 . 5/5.00 


STOCK NO.B5199 Microswitch keyboard. $45.00 2/80.00 Dual 741 Mini DIP B3112 . 5/5.00 


MINIMUM ORDER $5.00. include sufficient postage, excess 
DELTA ELECTRONICS CO refunded. Send for new 88 page Catalog 15, bigger than ever. 
. a 
A BANKAMERICARD and MASTERCHARGE 
BOX 1, LYNN, MASSACHUSETTS 01903 ттт now accepted, minimum charge $15.00. Please (uel 
Phone (617) 388-4705 include all numbers. Phone orders accepted. 
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the computer to correct your 
test for you. The second half 
of the book contains 50 
review problems covering 
many different interests: 
algebra, geometry, finance, 
statistics, puzzles and games. 
At the end is a set of program 
solutions to problems in the 
book. 

The reader will start to 
write simple programs after 
the first three pages. After 
that, more of the language is 
introduced bit by bit with 
activity reinforcement of 


RETAILING ? 


BYTE Magazine is very new. And judging by the response 
from retail outlets that want to sell BYTE, we're sure it has 
a grand and glorious future. 

If you own or know of a friend who owns a retail store 
(electronic parts, radio-T.V., hobby store, newsstand, 
student book store) we'd be more than happy to rush them 
our BYTE retail order form. 

We offer an extremely attractive discount, an unbeatable 
returns policy, and the only magazine for the serious 
computer hobbyist. More information? 


Discovering BASIC — A 
Problem Solving Approach by 
Robert E. Smith, Hayden 
Publishing Co., New York ach new command. 

NY, 1970. $7.95 hardcover, Lessons include: numbers 


$5.95 paperback. and variables, order of 
Write: calculations, built-in and user 


BYTE Magazine Anyone who wants to defined functions, flow 
Retail Sales Dept. learn BASIC for the Altair charting, program looping, 
Green Publishing, Inc. system or any other. BASIC printing headings, inputs 
Peterborough, N. H. 03458 | System should have this book. durin g execution, 


BYTE FOR RESALE 


explanations re make it оғ subroutines and matrices. 
easy to comprehend. All in all it isa very clear and 


The book is divided into comprehensive text for the 
37 two- to three-page lessons. learning of BASIC. 


There are four review tests Thoria CURE бөө 
and four test correcting 224 N. Alabama St. 
programs. Yes, you program San Gabriel CA 91775 


MICRO 440... the MORE 
affordable computer! 
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The MICRO 440, with a price intended to turn the competition’s 
hair gray. It’s built around the Intel 4040 CPU. And although it 
has only a 4-bit word, it's no toy. It features a powerful set of 60 
instructions to permit binary and decimal arithmetic, logic, 
loops and branching and real-time interrupts. It also features 
24 on-chip registers (more than many more expensive micros) 
and subroutine nesting to seven levels. With the bare-bones kit 
you get a single PC board housing CPU, clock, 1/0 interface, 
front panel controls and displays, and 256 bytes of 
program/data RAM. You also get our complete and instructive 
87-page manual. Order the complete kit, and you also get an 
enclosure, power supply, a standard input and output port and 
a standard Teletype interface. Need more memory? There's 
room for 8K of RAM or PROM memory, in 2K units. Each 
memory unit gives you extra 1/0 ports. 


The age of the microprocessor is here. They're already in 
sewing machines, parking garages, even pin-ball machines. 
Soon they'll be cooking your meals and controlling your TV. 
Have you been wanting to learn more about this exciting new 
technology? You could spend $300 to $600 to attend a course. 
Or, for less money, you can get unlimited hands-on experience 
with your own MICRO 440. With the basic kit you can enter a 
program up to 256 steps long, run and display the results. 
Following the simple instructions in our user's manual, you wiil 
learn the workings of the computer by loading and executing 
the many sample programs given, then learn to write your own 
programs. The usefulness of the MICRO 440 doesn't vanish as 
you learn. It's powerful enough to grow with you. Plug a 
Teletype or TV Typewriter into the back panel and greatly 
expand its capabilities. Add memory and peripherals, and 
you're ready for serious, efficient computing. 


Even fully expanded, the MICRO 440 won't cost you an arm and a leg. Would you believe a computer with 
2K PROM, 6K RAM, 32 1/0 ports, TTY interface, and a TV Typewriter for less than $1300? 


PRICES: Bare Bones Kit____... Ф 175 


Complete Kit $275 
Assembled & Tested... 5375 


PARTIAL KITS ALSO AVAILABLE. 
WRITE FOR PRICES. 


SULTANTS, Inc. 


RO. BOX 1016 
HUNTSVILLE, ALABAMA 35807 
205-837-5100 


LOGIC POWER SUPPLIES 


New Lambda transistorized, regulated, worth 2 or 3 times our price. 


1. (LVEE — 5) OV, 5 VDC 74amp ................................ 125.00 
2. (LWD — 12) 12 VDC 26.5 amp ................................. 100.00 
3. (LMB — 5) 5 VDC 3.7 amp .................................... 40.00 
4 (LMD — 15Y) 15 VDC 9amp .................................. 45.00 


DUX 


NS SOPHISTICATED LOGIC SUPPLIES 
SN : 


S 2 By Dressen-Barnes and NJE. Transistorized, 
finely filtered and regulated. 115 volt input. 


#61-5S Output 5VDC 21 Amp 27 Ib $47.50 
| #51-5S Output 5VDC 10.5 Amp 161b 35.00 
#421-32 Output 32VDC3.3Amp12Ib 20.00 
#421-90 Output 90VDC 1.2 Amp 121b 20.00 
#NJE 5VDC 34 Amp 35 Ib 75.00 
MEMORY SYSTEM $125.00 


New memory system by Honeywell, small . 
measures only 9x4x1 inches. 1024 core memory, 
1024 words with 8,9,10 bits/word. Random access, 
with all logic, register, timing, control, core select and 
sense functions in one package. New, booklet of 
schematics and data. Looks like a good beginning for 
a mini-computer. Limited supply on hand. 


Ship wgt 3 lbs. #SP-79 ......... $125.00 (ren gm 
n À 1,000uF  15volt $ .35 2,000 uF 35volt 1.00 
COMPUTER 2,000 15 50 19,500 25 $2.50 
CAPS 1,000 25 70 12,000 40 2.50 
BRAND 3,000 25 1.00 3,900 50 2.00 
NEW 1,000 35 .80 22,000 75 3.25 


CORE MEMORY 
Another brand new memory, ultra small. Measures only 4 x 4 inches 
with format on one plane of 32 x 32 x 16 (16,384). Only about 35 
units of this on hand. 


. slo. аан наа E. $20.00 
SANDERS 720 KEYBOARD....... $40.00 
FREE CATALOG 
f Please add shipping cost on above. 
4 
А "7 MESHNA PO Bx 62 E. Lynn Mass. 01904 
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reader 


BUTE service 


To get further information on the products advertised in this 
issue of BYTE merely tear, rip, or snip out this advertiser index, 
fill out the data at the bottom of the page, mark the appropriate 
boxes, and send the works to BYTE, Peterborough NH 03458. 
Readers get extra Brownie Points for sending for information 
since this encourages advertisers to keep using BYTE — which in 
turn brings you a bigger BYTE. 


ADVERTISER INDEX 


American Cancer Society 91 
ACM 15 

A. P. Products 2 
BYTE Subscriptions 95 
BYTE Retail Sales 110 
Bytronics 39 

Celdat 17 

Centi-Byte 18 

CMR 97 
Comp-Sultants 110 
Continental Specialties 81 
Delta Electronics 109 
Dutronics 98 
Godbout 6,7 

Hickok 97, 99 

lasis 56, 57 

IEEE 19 

Int'l Elec. Unltd. 103 
Intron 104 

James 105, 99 

Martin Research 16 
Meshna 111 

Micro Digital 77 
Mikra D 104 

MITS CIV, 40-47 
Ohio Scientific 102 
Processor Tech. 28, 29 
RGS 25 

Scelbi 62, 63 i 
Southwest Tech CIIN 
Sphere 11, 13 
Suntronix 107 
Teleterminal 106 
Tri-Tek 101 

о Visulex 102 

п Windjammer 92, 93 
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Messages for the editor: 


Reader’s Service 
BYTE DECEMBER 1975 


Green Publishing Inc. 


Peterborough NH 03458 BYTE acquired via 


O Subscription 


Please print or type. D Newsstand 


OStolen 
Name 
Address 
City State Zip 


Coupon expires in GO days... 


Feel free to photocopy this page if you wish to keep your BYTE intact. 
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THE 


BUTE 


QUESTIONNAIRE 


BYTE is dedicated to the needs of its readership. 
In order to better gauge matters of editorial policy 
and content, as well as to give our advertisers some 
“hard facts," we publish this questionnaire. In this 
month's list are a few more questions of editorial 
interest: 


What applications do you have in mind for your 
own personal computer system? 


Do you presently have a computer? 


If you own or use a personal computer system, 
what is its CPU chip or main frame computer 
design? 


Have you had any "on the job" training using 
computers as a tool for some purpose? 


Do you know what a computer language is? Would 
you list the computer languages (if any) which you 
know? 


These questions are a short form "letter to the 
editor." If you have additional comments, don't 
hesitate to write! Send completed questionnaires 
to BYTE, Dept. O, Peterborough NH 03458. 


Classified Ads Available for Individuals and Clubs 


Readers who have computer users only. 


equipment to buy, sell or swap 
should send in a clearly typed or 
printed notice to that effect. 
Insertions should be limited to 
approximately 100 words or 
less. Advertisements for this 
feature can be accepted from 
individuals or bona-fide clubs of 


Commercial advertisers should 
contact Bill Edwards, BYTE 
advertising manager, for the 
latest rate card and terms. 
Individual/club classifieds will 
be printed free on a space-avail- 
able basis in the earliest possible 
issue of BYTE. 


um 6800 


The Computer System You Have Been Waiting For 


A BENCHMARK SYSTEM—Using the MOTOROLA M6800 benchmark microprocessor family. 


COMPUTER 


sul 6800 svsrem 


Southwest Technical Products is proud to introduce the M6800 computer system. This system is based upon the 
Motorola MC6800 microprocessor unit (MPU) and it's matching family of support devices. The 6800 system was chosen 
for our computer because this set of parts is currently in our opinion the "Benchmark Family” for microprocessor 
systems. It makes it possible for us to provide you with a computer system having outstanding versitility and ease of use. 


In addition to the outstanding hardware system, the Motorola 6800 has without question the most complete set of 
documentation yet made available for a microprocessor system. The 714 page Applications Manual for example con- 
tains material on programming techniques, system organization, input/output techniques, and more. Also available is the 
Programmers Manual which details the various types of software available for the system and provides instructions for 
the programming and use of the unique interface system that is part of the 6800 design. The M6800 system minimizes 
the number of required components and support parts, provides extremely simple interfacing to external devices and 
has outstanding documentation. 


Our kit combines the MC6800 processor with the MIKBUG® read-only memory (ROM). This ROM contains the pro- 
gram necessary to automatically place not only a loader, but also a mini-operating system into the computers memory. 
This makes the computer very convenient to use because it is ready for you to enter data from the terminal keyboard 
the minute power is turned “ON”. Our kit also provides a serial control interface to connect a terminal to the system. 
This is not an extra cost option as in some inexpensive computers. The system is controlled from any ASCII coded ` 
terminal that you may wish to use. Our CT-1024 video terminal is a good choice. The control interface will also work 
with any 20 Ma. Teletype using ASCI! code, such as the ASR-33, or KSR-33. The main memory in our basic kit con- 
sists of 2,048 words (BYTES) of static memory. This eliminates the need for refresh interrupts and allows the system to 
operate at full speed at all times. Our basic kit is supplied with processor system, which includes the MIKBUG ROM, a 
128 word static scratch pad RAM, and clock oscillator bit rate divider; main memory board with 2,048 words, a serial 
control interface, power supply, cabinet with cover and complete assembly and operation instructions which include 
test programs and the Motorola Programmers Manual. 


MAIL THIS COUPON TODAY 
(JEnclosed is $450.00 [ 1 or Master C. # 
Oor BAC # ——— Ex Date ___. 

For My SWTPC Computer Kit[ ] L.] Send data package 


If you have a Motorola 6800 chip 
set, we will sell you boards, or any 
major part of this system as a separ- 
ate item. If you would like a full 


description and our price list, circle NAME 
the reader service number or send 
К ADDRESS 
the coupon today. Prices for a com- 
plete basic kit begin at only CITY STATE EI 


$450.00. 


Southwest Technical Products Corp., Box 32040, San Antonio, Texas 78284 


The MITS Altair 8800. 


(It's showing up in some of 


the most unusual places.) 


